?王者農藥皮膚圖片獲取!?
- 一、前言
- 二、環境準備
- 三、具體實作
- 1、所有英雄資訊獲取
- 2、分析圖片url
- 3、具體實作
- 4、結果
- 四、最后
完成目標:
??獲取王者官網英雄介紹頁面高清圖片
一、前言
??王者榮耀大家都玩過吧,沒玩過的也應該聽說過,作為時下最火的手機MOBA游戲,咳咳,好像跑題了,我們今天的重點是爬取王者榮耀所有英雄的所有皮膚!
二、環境準備
編輯器:pycharm
用到的庫:requests、lxml
三、具體實作
1、所有英雄資訊獲取
??打開官網,進入英雄資料頁面,通過開發者工具,得到所有的英雄的資料

??每一個英雄資料為json格式,共106個,其中一個顯示如下:

??解碼后,名稱如下:
{
'cname': '廉頗', # 英雄名稱
'ename': 105, # 英雄編號
'hero_type': 3, # 英雄型別
'new_type': 0,
'skin_name': '正義爆轟|地獄巖魂', # 英雄皮膚名稱
'title': '正義爆轟' # 當前皮膚
}
??這里主要需要的是 cname、ename、skin_name,skin_name用于獲取皮個數
2、分析圖片url
??打開一個英雄的詳情頁,打開開發者工具,以為云櫻為例,一共兩個皮膚,分別在兩個li標簽中,因此回圈兩次就可以全部拿到,也就是為什么之前要獲取skin_name的原因

??觀察url,尋找規律,其中前面的【//game.gtimg.cn/images/yxzj/img201606/skin/hero-info/】都是固定的,后面的是每個英雄的ename,然后ename-bigskin-skin_name的長度,因此,只要對這個url進行請求就可以得到高清壁紙
//game.gtimg.cn/images/yxzj/img201606/skin/hero-info/538/538-bigskin-1.jpg
//game.gtimg.cn/images/yxzj/img201606/skin/hero-info/538/538-bigskin-2.jpg
3、具體實作
from pprint import pprint
import requests
if __name__ == '__main__':
headers = {
"User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/92.0.4515.159 Safari/537.36 Edg/92.0.902.84"
}
baseurl = 'https://pvp.qq.com/web201605/js/herolist.json'
r = requests.get(url=baseurl, headers=headers)
data = r.json() # 英雄資料,包含cname、ename、skin_name
for i in data:
pprint(i) # 使用pprint列印資料原始格式
cname = i["cname"]
ename = i["ename"]
try:
skin_name = i["skin_name"].split("|") # 其中馬超沒有skin_name
except Exception as e:
print(e)
for skin_num in range(1, len(skin_name) + 1):
sk_url = 'http://game.gtimg.cn/images/yxzj/img201606/skin/hero-info/' + str(ename) + "/" + str(
ename) + "-bigskin-" + str(skin_num) + ".jpg" # url拼接
try:
data = requests.get(url=sk_url, headers=headers).content
with open("img/" + cname + "-" + skin_name[skin_num - 1] + ".jpg", "wb")as fp:
fp.write(data)
except Exception as e :
print(e)
print(ename,"下載完成...")
4、結果

四、最后
??中間會有skin_name例外,一定要捕獲例外,保證程式一直執行下去,并且出現了幾次IP例外,下次嘗試使用代理,
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/296889.html
標籤:python
