首页 > 编程语言 >【小白必看】使用Python批量下载英雄联盟皮肤图片的技术实现

【小白必看】使用Python批量下载英雄联盟皮肤图片的技术实现

时间:2023-10-18 16:07:40浏览次数:42  
标签:hero name 批量 Python img 皮肤 js 英雄 小白必

在这里插入图片描述

前言

英雄联盟是一款备受喜爱的团队对战游戏,游戏中每位英雄都有各种精美的皮肤供玩家选择。本文将介绍一个使用Python编写的英雄联盟皮肤下载器,可以快速获取所有英雄的皮肤图片,让您更方便地欣赏和收藏这些皮肤。

运行效果截图

在这里插入图片描述

导入必要的模块和库

在这里插入图片描述

import requests     # pip install requests
import re
from time import sleep
import os

定义常量和变量

在这里插入图片描述

all_hero_url ='https://lol.qq.com/biz/hero/champion.js'
headers = {'User-Agent':'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.70 Safari/537.36'}
  • all_hero_url:英雄URL地址
  • headers:请求头,用于模拟浏览器发送请求

获取所有英雄的名称

在这里插入图片描述

all_hero_js_resp = requests.get(all_hero_url,headers = headers)
all_hero_name = re.findall(r'"\d+?":"(\w+?)"',all_hero_js_resp.text)
  • 发送GET请求,获取英雄信息的JavaScript文件
  • 通过正则表达式提取所有英雄的名称,并存储在all_hero_name列表中

遍历每个英雄

在这里插入图片描述

for n in all_hero_name:
    sleep(1)
    hero_info_js_url =f'https://lol.qq.com/biz/hero/{n}.js'
    hero_info_js_resp = requests.get(hero_info_js_url,headers=headers)
    hero_info_js = hero_info_js_resp.text
    hero_ids = re.findall(r'"id":"(\d+?)"',hero_info_js)
    hero_names =  re.findall(r'"name":"(.+?)".+?"chrom',hero_info_js)
  • 遍历所有英雄的名称
  • 构造每个英雄的详细信息JavaScript文件URL
  • 发送GET请求,获取英雄详细信息的JavaScript文件
  • 通过正则表达式提取英雄ID和皮肤名称,并分别存储在hero_idshero_names列表中

遍历每个英雄的皮肤

for id,name in zip(hero_ids,hero_names):
    img_url =f'https://game.gtimg.cn/images/lol/act/img/skin/big{id}.jpg'
    # 发送请求
    img_resp = requests.get(img_url,headers=headers)
    name = name.encode().decode('unicode_escape')
    name = name.replace('/','')
    name = name.replace('\\','')
    print(f'正在下载{n}的:{name}皮肤')
    if not os.path.exists(f'./img/{n}'):
        os.mkdir(f'./img/{n}')
    with open(f'./img/{n}/{name}.jpg','wb') as f:
        f.write(img_resp.content)
    sleep(1)
  • 遍历每个皮肤的ID和名称
  • 构造每个皮肤的图片URL
  • 发送GET请求,获取皮肤图片内容
  • 对皮肤名称进行一些处理(编码转换、去除特殊字符)
  • 打印下载信息
  • 检查是否存在对应英雄的文件夹,如果不存在则创建
  • 将皮肤图片保存到文件夹中
  • 等待一秒,继续下载下一个皮肤

完整代码

import requests     # 导入requests模块,用于发送HTTP请求
import re           # 导入re模块,用于正则表达式匹配
from time import sleep   # 导入sleep函数,用于休眠

# 定义常量和变量
all_hero_url ='https://lol.qq.com/biz/hero/champion.js'   # 所有英雄URL地址
headers = {
   'User-Agent':'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.70 Safari/537.36'
}   # 请求头,用于模拟浏览器发送请求

# 获取所有英雄的名称
all_hero_js_resp = requests.get(all_hero_url,headers = headers)   # 发送GET请求,获取英雄信息的JavaScript文件
all_hero_name = re.findall(r'"\d+?":"(\w+?)"',all_hero_js_resp.text)   # 通过正则表达式提取所有英雄的名称,并存储在all_hero_name列表中

# 遍历每个英雄
for n in all_hero_name:
   sleep(1)   # 休眠1秒,避免请求频率过高被服务器拦截
   hero_info_js_url =f'https://lol.qq.com/biz/hero/{n}.js'   # 构造每个英雄的详细信息JavaScript文件URL
   hero_info_js_resp = requests.get(hero_info_js_url,headers=headers)   # 发送GET请求,获取英雄详细信息的JavaScript文件
   hero_info_js = hero_info_js_resp.text   # 获取JavaScript文件的内容
   hero_ids = re.findall(r'"id":"(\d+?)"',hero_info_js)   # 通过正则表达式提取英雄ID,并存储在hero_ids列表中
   hero_names =  re.findall(r'"name":"(.+?)".+?"chrom',hero_info_js)   # 通过正则表达式提取皮肤名称,并存储在hero_names列表中

# 遍历每个英雄的皮肤
for id,name in zip(hero_ids,hero_names):
   img_url =f'https://game.gtimg.cn/images/lol/act/img/skin/big{id}.jpg'   # 构造每个皮肤的图片URL
   img_resp = requests.get(img_url,headers=headers)   # 发送GET请求,获取皮肤图片内容
   name = name.encode().decode('unicode_escape')   # 对皮肤名称进行编码转换,解决中文字符显示问题
   name = name.replace('/','')   # 去除名称中的斜杠字符
   name = name.replace('\\','')   # 去除名称中的反斜杠字符
   print(f'正在下载{n}的:{name}皮肤')
   if not os.path.exists(f'./img/{n}'):
       os.mkdir(f'./img/{n}')   # 检查是否存在对应英雄的文件夹,如果不存在则创建
   with open(f'./img/{n}/{name}.jpg','wb') as f:   # 将皮肤图片保存到文件夹中
       f.write(img_resp.content)
   sleep(1)   # 休眠1秒,避免请求频率过高被服务器拦截
  • 第1行:导入requests模块,用于发送HTTP请求。
  • 第2行:导入re模块,用于正则表达式匹配。
  • 第3行:从time模块中导入sleep函数,用于程序休眠。
  • 第6行:定义常量all_hero_url,表示所有英雄URL地址。
  • 第7行:定义headers字典,包含用户代理信息,用于模拟浏览器发送请求。
  • 第10行:发送GET请求获取英雄信息的JavaScript文件,并将响应结果赋值给all_hero_js_resp
  • 第11行:使用正则表达式提取所有英雄的名称,并存储在all_hero_name列表中。
  • 第15行:使用for循环遍历每个英雄的名称。
  • 第16行:休眠1秒,以避免请求频率过高被服务器拦截。
  • 第17行:构造每个英雄的详细信息JavaScript文件URL。
  • 第18行:发送GET请求获取英雄详细信息的JavaScript文件,并将响应结果赋值给hero_info_js_resp
  • 第19行:获取JavaScript文件的内容。
  • 第20行:使用正则表达式提取英雄ID,并存储在hero_ids列表中。
  • 第21行:使用正则表达式提取皮肤名称,并存储在hero_names列表中。
  • 第25行:使用for循环遍历每个英雄的皮肤。
  • 第26行:构造每个皮肤的图片URL。
  • 第27行:发送GET请求获取皮肤图片内容,并将响应结果赋值给img_resp
  • 第28行:对皮肤名称进行编码转换,解决中文字符显示问题。
  • 第29行:去除名称中的斜杠字符。
  • 第30行:去除名称中的反斜杠字符。
  • 第31行:打印下载信息。
  • 第32-34行:检查是否存在对应英雄的文件夹,如果不存在则创建。
  • 第35行:将皮肤图片保存到对应的文件夹中。
  • 第36行:休眠1秒,以避免请求频率过高被服务器拦截。

代码使用Python的requests模块发送HTTP请求,使用re模块进行正则表达式匹配。通过解析游戏官网的数据接口,获取英雄和皮肤信息,并保存为本地文件。其中,sleep函数用于控制请求间隔,避免频繁请求导致被服务器拦截。代码还涉及文件和文件夹的操作,如创建文件夹、保存图片文件等。整体上,这段代码是一个简单的网络爬虫,用于批量下载英雄联盟的皮肤图片。

结束语

英雄联盟皮肤下载器是一个简单而实用的工具,让您能够快速获取所有英雄的皮肤图片。通过运行代码,您可以轻松地收集和保存英雄联盟中所有英雄的各种精美皮肤,无需手动下载。这个工具不仅适用于英雄联盟的玩家,也可以作为收藏者的便利工具,帮助您更好地欣赏和管理这些精美的皮肤设计。希望本文介绍的英雄联盟皮肤下载器对您有所帮助,让您在游戏中尽情享受每位英雄的独特魅力。

标签:hero,name,批量,Python,img,皮肤,js,英雄,小白必
From: https://blog.51cto.com/u_14522592/7918858

相关文章

  • 【小白必看】使用Python爬取喜马拉雅音频并保存的示例代码
    前言本文介绍了如何使用Python中的requests库来获取音频文件并保存到本地。在这个例子中,我们使用了喜马拉雅平台上的一个API接口来获取音频ID和名称,并使用这些信息构造音频地址,然后通过发送HTTP请求将音频内容下载保存到本地。运行效果截图导入requests库importrequests......
  • 【小白必看】Python爬取NBA球员数据示例
    前言使用Python爬取NBA球员数据的示例代码。通过发送HTTP请求,解析HTML页面,然后提取出需要的排名、姓名、球队和得分信息,并将结果保存到文件中。导入需要的库和模块importrequestsfromlxmlimportetree使用requests库发送HTTP请求。使用lxml库进行HTML解析。......
  • 【小白必看】Python词云生成器详细解析及代码实现
    前言本文介绍了如何使用Python编写代码来生成词云图。在生成词云图之前,我们需要导入一些必需的库,包括numpy、wordcloud、PIL、matplotlib.pyplot和openpyxl。其中,numpy用于数据处理,wordcloud用于生成词云,PIL用于图像处理,matplotlib.pyplot用于在笔记本中显示图片,openpyxl用于读......
  • 【小白必看】Python爬虫实战之批量下载女神图片并保存到本地
    前言爬取网络上的图片是一种常见的需求,它可以帮助我们批量下载大量图片并进行后续处理。本文将介绍如何使用Python编写一个简单的爬虫,从指定网页中获取女神图片,并保存到本地。运行结果部分图片1.引入所需库首先需要导入两个库:requests用于发送网络请求,lxml用于解析......
  • 【小白必看】Python图片合成示例之使用PIL库实现多张图片按行列合成
    前言本文介绍了一个用于图片合成的Python代码示例。该代码使用了PIL库来处理图片文件,并通过嵌套循环将多张图片按照指定的行数和列数进行合成。最终生成的合成图片保存在本地。效果图1.导入必要的库fromPILimportImageimportos这段代码导入了PIL库中的Image模块,......
  • 【玩转python系列】【小白必看】使用Python爬虫技术获取代理IP并保存到文件中
    前言这篇文章介绍了如何使用Python爬虫技术获取代理IP并保存到文件中。通过使用第三方库requests发送HTTP请求,并使用lxml库解析HTML,我们可以从多个网页上获取IP、Port和地址信息。本文将逐步解析代码的每一部分,帮助读者更好地理解爬虫的工作原理。导入依赖库importrequ......
  • 【玩转Python系列】【小白必看】使用Python爬取双色球历史数据并可视化分析
    前言本文介绍了如何使用Python编程语言获取双色球历史数据,并使用数据可视化工具Matplotlib绘制了红球数量的折线图。通过对双色球历史数据的分析,我们可以更好地了解双色球的开奖规律和趋势。导入库importrequestsfromlxmlimportetreeimportcsvimportmatplotlib.pypl......
  • 【玩转Python系列【小白必看】Python多线程爬虫:下载表情包网站的图片
    前言本文主要介绍了使用Python编写的多线程爬虫程序,用于下载表情包网站上的图片。通过解析网页内容和使用XPath定位,可以获取到图片的URL,并将其保存到本地。1.导入模块和库importrequestsfromlxmlimportetreefromthreadingimportThreadfromqueueimportQueueim......
  • 【python】Python tkinter库实现重量单位转换器的GUI程序
    前言这段代码是一个简单的重量单位转换器的GUI程序,使用了Python的tkinter库来创建图形界面。该程序可以将输入的重量从千克转换为克、磅和盎司,并通过三个文本框分别显示转换后的结果。学到什么?使用tkinter库创建一个GUI窗口。tkinter是Python标准库中的一个模块,用于......
  • 【Python】Python 实现猜单词游戏——挑战你的智力和运气!
    前言大家好!欢迎来到我们精心准备的文字游戏世界。今天,我将向大家介绍一款有趣而又考验智力的游戏——猜单词游戏。在游戏中,你将面临一个神秘的单词,你需要凭借自己的智慧和运气来猜测这个单词是什么。每猜错一次,你将失去一条生命线,当生命线用尽时,你将面临失败。但只要你成功猜对了......