python爬取lol官网英雄图片代码 v2.8 v2.8
发布时间:2020-11-24
软件语言:简体中文
软件大小:1KB
软件授权:免费版
软件版本:v2.8
相关链接:软件官网
软件类型:国产软件
软件平台:WinXp,Win2003,WinVista,Win 7,Win 8,Win 10,x64
软件类型: 编程软件  /  程序源码
关键字:python爬取lol官网英雄图片代码
软件评分:
python爬取lol官网英雄图片代码可以帮助用户对英雄联盟官网平台的皮肤图片进行抓取,有很多喜欢lol的玩家们想要官方的英雄图片当作自己的背景或者头像,可以使用这款软件为你爬取图片资源,操作很简单,设置一些保存路径就可以将图片保存到这个文件夹里了。

作者说明

因为最近在学习python,这个代码也是百度了很长时间来写的。确实不会英语。。对英语一点也不敏感!虽然某易论坛已经有python的中文模块了,但是不想去用中文,也算是挑战一下自己把!自己对易语言比较熟悉,所以有点经验来写python,从另一个角度来说的话,python也算比较好理解!下面的代码注释写的很详细!可以一起学习!算是给自己的第一课吧!

代码使用

下面截图没有爬完的效果图(图片大小为980*500或者1024*630的图片);所以这个清晰度还不叫壁纸吧!python爬取lol官网英雄图片代码

代码一览

import requests,os,json,time#requests为网页操作模块;用来取出英雄列表和皮肤列表#os为系统模块,用来写文件和创建目录#json为json解析模块,用来解析返回的数据#time为时间模块,用来延时js = requests.get('https://game.gtimg.cn/images/lol/act/img/js/heroList/hero_list.js')#先访问这个网址,获取英雄列表herolist = js.json()#取出返回的json格式for i in herolist['hero']:#循环英雄列表name = i['name']#取出英雄的名字if os.path.exists('LOL壁纸'):#判断根目录是否存在print('创建目录失败,目录已存在;')else:#不存在就创建这个目录os.mkdir('LOL壁纸')print('创建目录:LOL壁纸;')if os.path.exists('LOL壁纸\' + i['name']):#判断根目录LOL壁纸下子目录为英雄名的目录是否存在print('创建目录失败,目录已存在;')else:#如果不存在就创建这个目录os.mkdir('LOL壁纸\' + i['name'])print('创建目录')heroID = i['couponPrice']#赋值英雄idenglish_name = i['alias']#赋值英雄的英文名photos_back = requests.get(f'http://lol.qq.com/biz/hero/{english_name}.js')#读取以英雄英文名.js的网址来获取皮肤列表photos_back_text = photos_back.text#取出来返回的字符串photos_back_text = photos_back_text.replace('if(!LOLherojs)var LOLherojs={champion:{}};LOLherojs.champion.'+english_name+'=','')photos_back_text = photos_back_text.replace(';', '')photos_back_text = json.loads(photos_back_text)#以上两行行处理一下返回的字符串用来转换为json的格式for n in photos_back_text['data']['skins']:#循环一下皮肤列表photos_back_byte = requests.get(f'https://game.gtimg.cn/images/lol/act/img/skin/big{n["id"]}.jpg')#读取一下以皮肤ID为网址的图片地址if n['name'] == 'default':#判断一下是不是默认皮肤skin_name = str(name)#如果是默认皮肤,就以英雄名字来命名else:#如果不是就以皮肤名字命名skin_name = str(n['name'])print(f'英雄名:{name};英雄ID:{heroID};皮肤ID:{n["id"]};英雄英文名:{english_name};皮肤名字:{skin_name};')#将状态打印出来if skin_name.find('/') != -1:#后面运行的时候发现一个问题,如果皮肤名字有一个'/'字符串的话直接就会报错,所以这里来寻找一下皮肤名字有没有'/'这个字符串skin_name = skin_name.replace('/','')#如果存在这个字符串就把他替换掉wb = open('LOL壁纸\' + name+'\'+ skin_name +'.jpg','wb')#打开这个图片文件wb.write(photos_back_byte.content)#把读取出来的图片网址以字节集的形式保存文件wb.close()#关闭这个文件print(f'保存{name}的{skin_name}成功!')#打印保存成功print('延迟3秒继续')time.sleep(3)#延迟3秒,运行的时候发现如果速度过快,网站就会返回错误信息以上就是python爬取lol官网英雄图片代码的全部内容了,快快收藏非凡软件站下载更多软件和游戏吧!
软件截图
最新更新
下载地址