IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Python知识库 -> Python?30行代码?爬取王者荣耀所有英雄皮肤图片? -> 正文阅读

[Python知识库]Python?30行代码?爬取王者荣耀所有英雄皮肤图片?

? ? ? ? 嗨喽~小伙伴们我又来了,

? ? ? ? 众所周知,python在爬虫领域有着得天独厚的优势,今天,咱整点有意思的应用-----用python爬取王者荣耀所有英雄皮肤图片。

? ? ? ? 本章中,我会着重带大家了解爬取网页的基本流程。废话不多说,走起......

? ? ? ? 首先,咱去王者荣耀的官网瞧瞧:王者荣耀官方网站-腾讯游戏?(建议用谷歌浏览器)

? ? ? ? 我们的目标是,找到英雄皮肤的url地址,如下图,官网是这样的:

? ? ? ? 发现图中的红框部分-----英雄资料,点进去看看:

? ? ? ? 往下滑,我们可以发现好多的英雄头像,点一个进去看看,比如貂蝉姐姐:

?

? ? ? ? 如上图,我们看到了貂蝉的所有皮肤,?现在我们要找到这些皮肤的url地址,鼠标放至皮肤图片处,在谷歌浏览器中,按F12调出开发者工具,可以看到如下内容:

? ? ? ? ?我们找到了这个皮肤的url地址:

? ? ? ? “https://game.gtimg.cn/images/yxzj/img201606/skin/hero-info/141/141-bigskin-7.jpg

? ? ? ? 再换一个皮肤试试:

????????

? ? ? ? 她的url地址为:

? ? ? ? “https://game.gtimg.cn/images/yxzj/img201606/skin/hero-info/141/141-bigskin-6.jpg

?????????对比这两张皮肤图片的url地址:

????????“https://game.gtimg.cn/images/yxzj/img201606/skin/hero-info/141/141-bigskin-7.jpg

? ? ? ? “https://game.gtimg.cn/images/yxzj/img201606/skin/hero-info/141/141-bigskin-6.jpg

? ? ? ? 我们发现,这两个url地址,仅仅是最后一个数字不同,我们猜测,这个数字应该是不同皮肤的某种编号

? ? ? ? 接着,我们继续看看其他英雄的皮肤图片,如百里守约,同貂蝉的一样,我们找到了百里的几个皮肤的url地址如下:

? ? ? ? “https://game.gtimg.cn/images/yxzj/img201606/skin/hero-info/196/196-bigskin-2.jpg

? ? ? ? “https://game.gtimg.cn/images/yxzj/img201606/skin/hero-info/196/196-bigskin-3.jpg”?

? ? ? ? “https://game.gtimg.cn/images/yxzj/img201606/skin/hero-info/196/196-bigskin-4.jpg”?

? ? ? ? 从这三个url地址可以发现,百里的皮肤url地址,也仅仅最后一个数字不同,?同样,我们猜测这应该代表着百里不同皮肤的编号。

? ? ? ? 接着,我们对比一下貂蝉和百里的皮肤url地址有何不同:?

? ? ? ? “https://game.gtimg.cn/images/yxzj/img201606/skin/hero-info/141/141-bigskin-6.jpg

? ? ? ? “https://game.gtimg.cn/images/yxzj/img201606/skin/hero-info/196/196-bigskin-2.jpg

? ? ? ? 我们发现,两个英雄皮肤除了编号(最后一个数字)不同,最大的不同是 /hero-info/ 后面的整数,貂蝉的是141,而百里的是196,据此猜测,这个整数应该是代表的是英雄的编号,至此,我们猜测,所有英雄皮肤的url地址的命名路径应该长下面这个样子:

? ? ? ? “https://game.gtimg.cn/images/yxzj/img201606/skin/hero-info/{英雄编号}/{英雄编号}-bigskin-{皮肤编号}.jpg”?

? ? ? ? 地址找到了,现在的问题是,如何找到所有英雄的编号呢?

? ? ? ? 我们继续逛逛王者荣耀的官网,找找针对王者里的英雄还有哪些数据可以利用,几番寻找,我们发现了一个叫 herolist.json 的文件,

????????(地址为:https://pvp.qq.com/web201605/js/herolist.json?):

? ? ? ? ?用浏览器打开这个json文件,神奇的事情发生了:

?

? ? ? ? ?不知道大家对上图中貂蝉的“ename”属性的值“141”这个数据还有没有印象,没错!它不正是貂蝉的编号嘛!

????????上图中,百里的编号“196”也印证了我们的猜测。

? ? ? ? 有了上述的分析,要爬取所有英雄的皮肤图片,就轻松多了。

? ? ? ? 在这,我们不使用 python 的 webdriver 等库,而采用最基础的 requests 库来完成我们的爬取工作,代码如下:


import requests
import os
import json


def download_wzry_hero_picture():
    url1 = 'https://pvp.qq.com/web201605/js/herolist.json'
    response = requests.get(url1).text  # 获取url页面内容,此处为json文本
    dict_hero_info = json.loads(response)  # 将json格式的数据转化为字典
    for key in dict_hero_info:  # 遍历字典
        name = key['cname']  # 英雄名字
        id = key['ename']  # 英雄编号
        # 如果没有skin_name,则输出:"无图片"
        skin_name_default = key.setdefault('skin_name', '无图片')
        print(skin_name_default)
        count = skin_name_default.count('|')  # 利用 count() 查询字符出现的次数
        skin_name_list = skin_name_default.split('|')  # 利用 split() 分割字符返回列表
        if not os.path.exists(name):  # 创建图片保存的文件夹
            os.mkdir(name)
        for i in range(1, count + 1):
            # 构造英雄皮肤地址
            url2 = 'http://game.gtimg.cn/images/yxzj/img201606/skin/hero-info/%s/%s-bigskin-%d.jpg' % (id, id, i)
            img = requests.get(url2)  # 获取图片的二进制数据
            print(url2)
            pictName = skin_name_list[i]
            # 下载并保存图片
            with open(name + '/' + pictName + '.jpg', 'wb') as f:
                f.write(img.content)  # 写入图片
                print('成功下载并保存图片~')


# 程序入口
if __name__ == '__main__':
    download_wzry_hero_picture()

? ? ? ? 点击运行,在控制台可以看到下载进度:

? ? ? ? 下载完成后,在当前目录下,我们能看到生成的所有英雄皮肤图片的文件夹:?

? ? ? ? 下面,就让我们尽情的欣赏英雄们的图片吧~?

????? ??

?????????

?????????

?????????

?????????

? ? ? ? 最后,喜欢的小伙伴们点个赞鼓励支持一下吧~?

  Python知识库 最新文章
Python中String模块
【Python】 14-CVS文件操作
python的panda库读写文件
使用Nordic的nrf52840实现蓝牙DFU过程
【Python学习记录】numpy数组用法整理
Python学习笔记
python字符串和列表
python如何从txt文件中解析出有效的数据
Python编程从入门到实践自学/3.1-3.2
python变量
上一篇文章      下一篇文章      查看所有文章
加:2021-10-08 11:45:45  更:2021-10-08 11:46:04 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/5 8:47:47-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码