大佬教程收集整理的这篇文章主要介绍了⚡王者农药皮肤图片获取!⚡,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
完成目标: 获取王者官网英雄介绍页面高清图片
王者荣耀大家都玩过吧c;没玩过的也应该听说过c;作为时下最火的手机MOBA游戏c;咳咳c;好像跑题了。我们今天的重点是爬取王者荣耀所有英雄的所有皮肤!
编辑器:pycharm 用到的库:requests、lxml
打开官网c;进入英雄资料页面c;通过开发者工具c;得到所有的英雄的数据
{
'cname': '廉颇', # 英雄名称
'ename': 105, # 英雄编号
'hero_type': 3, # 英雄类型
'new_type': 0,
'skin_name': '正义爆轰|地狱岩魂', # 英雄皮肤名称
'title': '正义爆轰' # 当前皮肤
}
这里主要需要的是 cname、ename、skin_namec;skin_name用于获取皮个数
打开一个英雄的详情页c;打开开发者工具c;以为云樱为例c;一共两个皮肤c;分别在两个li标签中c;因此循环两次就可以全部拿到c;也就是为什么之前要获取skin_name的原因
//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
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() # 英雄资料c;包含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,"下载完成...")
中间会有skin_name异常c;一定要捕获异常c;保证程序一直执行下去,并且出现了几次IP异常c;下次尝试使用代理。
以上是大佬教程为你收集整理的⚡王者农药皮肤图片获取!⚡全部内容,希望文章能够帮你解决⚡王者农药皮肤图片获取!⚡所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。