本篇文章為大家展示了python怎么爬取王者榮耀全皮膚的簡單實現(xiàn)代碼,內(nèi)容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。
讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來自于我們對這個行業(yè)的熱愛。我們立志把好的技術(shù)通過有效、簡單的方式提供給客戶,將通過不懈努力成為客戶在信息化領(lǐng)域值得信任、有價值的長期合作伙伴,公司提供的服務(wù)項目有:域名注冊、雅安服務(wù)器托管、營銷軟件、網(wǎng)站建設(shè)、威寧網(wǎng)站維護、網(wǎng)站推廣。
相信現(xiàn)在很多人都喜歡玩王者榮耀這款手游,里面好看的皮膚令人愛不釋手。那么你有沒有想過把王者榮耀高清皮膚設(shè)置為壁紙,像下面這樣
如何利用python代碼實現(xiàn)王者榮耀全部高清皮膚的下載。
具體的操作分為兩步:
1. 找到皮膚圖片的地址
2. 下載圖片
1. 尋找皮膚圖片的地址 1. 找到英雄列表
百度"王者榮耀"進入官網(wǎng) https://pvp.qq.com/。這里以Goole Chrome瀏覽器為例,在更多工具中選擇開發(fā)者工具,或直接按F12進入調(diào)試界面,然后按F5刷新界面
圖中標(biāo)識的herolist.json文件就是我們所需要的英雄列表,其中包括英雄編號、英雄名稱、英雄類型、皮膚的名稱等信息,在文件上右擊復(fù)制鏈接,http://pvp.qq.com/web201605/js/herolist.json
接下來驗證一下我們尋找的是否正確,代碼1:
import urllib.requestimport jsonimport osresponse = urllib.request.urlopen("http://pvp.qq.com/web201605/js/herolist.json")hero_json = json.loads(response.read())hero_num = len(hero_json)print(hero_json)print("hero_num : " , str(hero_num))
以上代碼讀取英雄列表并存入hero_json,并獲取英雄數(shù)量,運行效果如下圖
2. 找到英雄皮膚地址
點擊首頁的“游戲資料”標(biāo)簽頁,進入新的頁面后隨意點擊一個英雄頭像進入英雄資料頁面,以李白為例。同樣的F12然后F5,將鼠標(biāo)在李白的幾個皮膚上一次掃過,
來看調(diào)試窗口
可以看到李白的高清皮膚一共有5個,同樣我們在一個皮膚上右鍵復(fù)制鏈接得到:
/upload/otherpic52/44775.jpg
這就是我們想要得到的英雄皮膚鏈接。
分析這個鏈接我們可以發(fā)現(xiàn),其中‘131'是英雄的編號,最后的'-5'是該英雄的皮膚編號。到這里,瀏覽器上所需要的信息我們已經(jīng)全部獲得。
2. 下載圖片 1. 英雄有幾個皮膚
在第一步獲取到的herolist.json文件中有'skin_name'字段,我們只要解析這個字段就可以獲取皮膚數(shù)量與名稱。測試代碼接代碼1,代碼2如下:
hero_name = hero_json[0]['cname']skin_names = hero_json[0]['skin_name'].split('|')skin_num = len(skin_names)print('hero_name: ', hero_name)print('skin_names :', skin_names)print('skin_num: ' + str(skin_num))
測試后的運行結(jié)果如下:
可以看到廉頗一共兩個皮膚,皮膚名稱分別為:正義爆轟和地獄巖魂。
2. 下載文件
下載文件用到urlretrieve接口,并且考慮兩個問題:
1. 檢查文件夾是否存在,不存在則創(chuàng)建;
save_dir = 'D:\heroskin\\'if not os.path.exists(save_dir):os.mkdir(save_dir)
2. 檢查圖片文件是否存在,如果存在則跳過下載。
if not os.path.exists(save_file_name):urllib.request.urlretrieve(skin_url, save_file_name)
代碼三如下:
save_dir = 'D:\heroskin\\'if not os.path.exists(save_dir): os.mkdir(save_dir) for i in range(hero_num): # 獲取英雄皮膚列表 skin_names = hero_json[i]['skin_name'].split('|') for cnt in range(len(skin_names)): save_file_name = save_dir + str(hero_json[i]['ename']) + '-' +hero_json[i]['cname']+ '-' +skin_names[cnt] + '.jpg' skin_url = 'http://game.gtimg.cn/images/yxzj/img201606/skin/hero-info/'+str(hero_json[i]['ename'])+ '/' +str(hero_json[i]['ename'])+'-bigskin-' + str(cnt+1) +'.jpg' print(skin_url) if not os.path.exists(save_file_name): urllib.request.urlretrieve(skin_url, save_file_name)
總結(jié)
最后完整代碼如下,除去注釋和空行一共16行代碼,實現(xiàn)了下載王者榮耀全部高清皮膚的功能:
import urllib.requestimport jsonimport osresponse = urllib.request.urlopen("http://pvp.qq.com/web201605/js/herolist.json")hero_json = json.loads(response.read())hero_num = len(hero_json)save_dir = 'D:\heroskin\\'if not os.path.exists(save_dir): os.mkdir(save_dir) for i in range(hero_num): # 獲取英雄皮膚列表 skin_names = hero_json[i]['skin_name'].split('|') for cnt in range(len(skin_names)): save_file_name = save_dir + str(hero_json[i]['ename']) + '-' +hero_json[i]['cname']+ '-' +skin_names[cnt] + '.jpg' skin_url = 'http://game.gtimg.cn/images/yxzj/img201606/skin/hero-info/'+str(hero_json[i]['ename'])+ '/' +str(hero_json[i]['ename'])+'-bigskin-' + str(cnt+1) +'.jpg' print(skin_url) if not os.path.exists(save_file_name): urllib.request.urlretrieve(skin_url, save_file_name)
哈哈,看來掌握一門語言是多么的重要。
上述內(nèi)容就是python怎么爬取王者榮耀全皮膚的簡單實現(xiàn)代碼,你們學(xué)到知識或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識儲備,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。