鱼C论坛

 找回密码
 立即注册
查看: 2629|回复: 2

[作品展示] 【Python】爬取王者荣耀全英雄全皮肤高清大图

[复制链接]
发表于 2019-10-7 17:02:02 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
  1. '''
  2. 爬取王者荣耀全英雄全皮肤高清图
  3. '''

  4. import urllib.request
  5. import os
  6. import time

  7. #打开一个页面
  8. def open_page(url):
  9.     req = urllib.request.Request(url)
  10.     req.add_header('User-Agent',
  11.                    'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/77.0.3865.75 Safari/537.36')
  12.     reponse = urllib.request.urlopen(req)
  13.     html = reponse.read()
  14.     return html

  15. #获取英雄:编号为键值对的字典,并为每个英雄创建一个文件夹
  16. def get_hero(str):
  17.     hero_dict = {}
  18.     num_a = str.find('src="//game.gtimg.cn/images/yxzj/img201606/heroimg/') + 51

  19.     while num_a != 50:
  20.         num_b = num_a + 3
  21.         hero_a = str.find('alt=',num_b) + 5
  22.         hero_b = str.find('">', hero_a)
  23.         hero = str[hero_a : hero_b]
  24.         num = str[num_a : num_b]
  25.         hero_dict[hero] = num
  26.         os.mkdir(hero)
  27.         num_a = str.find('src="//game.gtimg.cn/images/yxzj/img201606/heroimg/', num_b) + 51

  28.     return hero_dict

  29. #获取当前英雄皮肤名称:皮肤编号为键值对的字典
  30. def get_skin(str):
  31.     skin_dict = {}

  32.     skin_a = str.find('data-imgname="') + 14
  33.     skin_b = str.find('">', skin_a)
  34.     skin = str[skin_a : skin_b]
  35.     skin_list = skin.split('|')
  36.     for i in range(len(skin_list)):
  37.         skin_dict[skin_list[i]] = i + 1

  38.     return skin_dict

  39. #通过传入的皮肤名称和编号进行图片保存
  40. def save_skin(hero_name, name, skin_num, hero_num):
  41.     url = f'http://game.gtimg.cn/images/yxzj/img201606/skin/hero-info/{hero_num}/{hero_num}-bigskin-{skin_num}.jpg'
  42.     html = open_page(url)
  43.     file_name = hero_name + ' - ' + name + '.jpg'
  44.     with open(file_name, 'wb') as f:
  45.         f.write(html)
  46.         time.sleep(3)

  47. #定义主函数
  48. def honor_skin():
  49.     cnt = 0
  50.     url_main = 'https://pvp.qq.com/web201605/herolist.shtml'
  51.     url_part = 'https://pvp.qq.com/web201605/herodetail/'
  52.     dirs = '荣耀皮肤'
  53.     os.mkdir(dirs)
  54.     os.chdir(dirs)

  55.     html_main = open_page(url_main).decode('gbk')
  56.     hero_dict = get_hero(html_main)

  57.     for i in hero_dict:
  58.         hero_num = hero_dict[i]
  59.         url_hero = url_part + hero_num + '.shtml'
  60.         html_hero = open_page(url_hero).decode('gbk')
  61.         skin_dict = get_skin(html_hero)
  62.         os.chdir(i)
  63.         for key, value in skin_dict.items():
  64.             save_skin(i, key, value, hero_num)
  65.             cnt += 1
  66.             print(f'已成功保存{cnt}张皮肤,别鸡巴着急,等着的....')
  67.         print(f'{i} 的皮肤已下载完毕!')
  68.         os.chdir('..')

  69. #好习惯要坚持
  70. if __name__ == '__main__':
  71.     honor_skin()
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2019-10-8 14:46:35 | 显示全部楼层
斯国一
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-18 11:31:02 | 显示全部楼层
这么好的帖子居然沉了
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-30 22:55

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表