743567274 发表于 2020-11-23 01:11

记一下;新手爬LOL官网英雄皮肤图片,应该还称不上叫壁纸

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

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


下面是代码:
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']#赋值英雄id
    english_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秒,运行的时候发现如果速度过快,网站就会返回错误信息

QAQ! 发表于 2020-11-23 02:03

不能当壁纸 可以当头像:lol

骑行吧 发表于 2020-11-23 09:09

hunzi 发表于 2020-11-23 09:04
photos_back_text = photos_back_text.replace('if(!LOLherojs)var LOLherojs={champion:{}};LOLherojs ...

这是字符串替换
把'if(!LOLherojs)var LOLherojs={champion:{}};LOLherojs.champion.'+english_name+'='这个字符串替换为空。

sauterne 发表于 2020-11-23 02:12

赞,不用下载新的包就可以

VainAlex 发表于 2020-11-23 02:25

强,还没开始学

david4801 发表于 2020-11-23 06:43

手游LOL不知道能不能搞来

guccipig 发表于 2020-11-23 07:29

厉害厉害

ahehaoyu 发表于 2020-11-23 07:47

教程很消息   感谢分享

猫儿扛着枪 发表于 2020-11-23 07:50

感谢分享

xiaowu906 发表于 2020-11-23 07:51

牛{:1_893:},学习一下,也来搞一波

haidibingjing 发表于 2020-11-23 07:59

学习一波~~~
页: [1] 2 3 4
查看完整版本: 记一下;新手爬LOL官网英雄皮肤图片,应该还称不上叫壁纸