美文网首页
Python实现王者荣耀所有英雄皮肤采集

Python实现王者荣耀所有英雄皮肤采集

作者: 颜狗一只 | 来源:发表于2023-11-20 14:32 被阅读0次

嗨喽,大家好呀~这里是爱看美女的茜茜呐

环境使用:

  • Python 3.10

  • Pycharm

模块使用:

  • requests —> 数据请求模块 需要安装 pip install requests

  • re 正则表达式 内置模块 不需要安装

  • os 文件操作模块 内置模块 不需要安装

如何安装python第三方模块:

  1. win + R 输入 cmd 点击确定, 输入安装命令 pip install 模块名 (pip install requests) 回车

  2. 在pycharm中点击Terminal(终端) 输入安装命令

案例分为两部分:

  1. 选择英雄皮肤图片下载

  2. 对应所有英雄数据进行下载

案例基本思路流程:

一. 数据来源分析

  1. 明确需求: 明确采集的网站以及数据

  2. 抓包分析: 皮肤图片

    通过开发者工具分析图片链接是什么样子, 怎么构成 怎么生成

    • 打开开发者工具: F12 / 右键点击检查选择 network (网络)

    • 刷新网页: 让本网页的数据内容重新加载一遍

      比如动态网页: 点击第二页/下一页数据, 下滑页面加载新的页面的内容

    • 分析图片链接是什么样子的…

      图片链接: https://game.gtimg.cn/images/yxzj/img201606/skin/hero-info/109/109-bigskin-{1~10}.jpg

      昵称: 通过关键词去搜索对应位置

       https://pvp.qq.com/web201605/herodetail/109.shtml
      
      

二. 代码实现步骤

  1. 发送请求 -> 模拟浏览器对于url地址发送请求

    请求网址: https://pvp.qq.com/web201605/herodetail/109.shtml

  2. 获取数据 -> 服务器返回响应数据

    开发者工具: 响应 response

  3. 解析数据 -> 提取我们需要皮肤昵称 以及 构建图片链接地址

  4. 保存数据 -> 获取图片数据, 保存本地文件夹

代码展示

# 导入数据请求模块 <需要安装>
import requests
# 导入正则表达式模块 <内置模块>
import re
# 导入文件操作模块 <内置模块>
import os

“”"

发送请求

  • 模拟浏览器对于url地址发送请求

    <Response [200]> 响应对象, 表示请求成功

“”"

# 模拟伪装 <请求头>
headers = {
    # User-Agent 用户代理 表示浏览器基本身份信息
    'User-Agent':'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/119.0.0.0 Safari/537.36'
}
# 请求网址:
link = 'https://pvp.qq.com/web201605/js/herolist.json'
# 发送请求
json_data = requests.get(url=link, headers=headers).json()
for index in json_data:
    hero_id = index['ename']
    hero_name = index['cname']
    print(hero_name, hero_id)
    filename = f'img\\{hero_name}\\'
    if not os.path.exists(filename):
        os.makedirs(filename)
    # 请求网址
    url = f'https://pvp.qq.com/web201605/herodetail/{hero_id}.shtml'
    # 发送请求
    response = requests.get(url=url, headers=headers)

“”"

获取数据

response.text 获取响应文本数据

  • 当获取文本数据时, 发生乱码如何解决?

    解决方法: 改编码

“”"

    # 改编码
    response.encoding = response.apparent_encoding
    html_data = response.text

“”"

解析数据

  • re.findall(‘匹配的数据’, ‘数据源’)

“”"

    info = re.findall('data-imgname="(.*?)">', html_data)[0].split('|')
    # 构建图片链接地址 len(info) 统计元素个数
    for i in range(len(info)): # i -> 0-9
        img = f'https://game.gtimg.cn/images/yxzj/img201606/skin/hero-info/{hero_id}/{hero_id}-bigskin-{i+1}.jpg'
        title = info[i].split('&')[0] # 列表索引位置取值
        print(img, title)

“”"

保存数据

“”"

        # 获取图片内容
        img_content = requests.get(url=img, headers=headers).content
        with open(filename + title + '.jpg', mode='wb') as f:
            f.write(img_content)

图片展示

尾语

感谢你观看我的文章呐~本次航班到这里就结束啦 🛬

希望本篇文章有对你带来帮助 🎉,有学习到一点知识~

躲起来的星星🍥也在努力发光,你也要努力加油(让我们一起努力叭)。

相关文章

网友评论

      本文标题:Python实现王者荣耀所有英雄皮肤采集

      本文链接:https://www.haomeiwen.com/subject/mwevwdtx.html