共计 4636 个字符,预计需要花费 12 分钟才能阅读完成。
这是通过博主写的英雄联盟下载器下载的局部的英雄皮肤,能够看一下成果。每个英雄的皮肤的会主动依据英雄名称创立相应的文件夹寄存。
【浏览全文】
残缺源代码请浏览到文末获取 …
实现思路比较简单,同样是通过 PyQt5 来编写下载页面。最初通过 request 模块来进行皮肤的下载局部编写。演示一下操作过程是上面这样的,抉择好皮肤的存储门路。而后间接点击开始下载就行了,并且能够在文本浏览器中查看下载进度信息。
接下来,介绍一下代码块的次要是实现局部。首先,介绍一下整个代码块都应用了哪些第三方模块。
# 英雄联盟皮肤下载相干依赖模块
import requests # 网络申请库
import re # 正则表达式匹配库
import json # JSON 格局转换库
import os # 利用操作库
import time # 工夫模块
from random import random # 随机数模块
from fake_useragent import UserAgent # user_agent 生成库
import logging # 日志模块
import sys # 零碎操作
# pyqt5 的模块援用这里就不介绍了,最近始终在用。from PyQt5.QtGui import *
from PyQt5.QtWidgets import *
from PyQt5.QtCore import *
UI 界面的设计过程代码块以及信号与槽函数的利用过程。
def init_ui(self):
self.setWindowTitle('英雄皮肤下载器 公众号:[Python 集中营]')
self.setWindowIcon(QIcon('lol.ico'))
self.resize(500,250)
vbox = QVBoxLayout()
self.save_dir = QLineEdit()
self.save_dir.setReadOnly(True)
self.save_btn = QPushButton()
self.save_btn.setText('门路')
self.save_btn.clicked.connect(self.save_btn_click)
self.thread_ = DownLoadThread(self)
self.thread_.trigger.connect(self.update_log)
self.start_btn = QPushButton()
self.start_btn.setText('开始下载')
self.start_btn.clicked.connect(self.start_btn_click)
grid = QGridLayout()
grid.addWidget(self.save_dir, 0, 0, 1, 2)
grid.addWidget(self.save_btn, 0, 2, 1, 1)
grid.addWidget(self.start_btn, 0, 3, 1, 1)
self.result_brower = QTextBrowser()
self.result_brower.setFont(QFont('宋体', 8))
self.result_brower.setReadOnly(True)
self.result_brower.setPlaceholderText('英雄皮肤批量下载进度显示区域...')
self.result_brower.ensureCursorVisible()
vbox.addWidget(self.result_brower)
vbox.addLayout(grid)
self.setLayout(vbox)
def start_btn_click(self):
self.start_btn.setEnabled(False)
self.thread_.start()
def update_log(self, text):
cursor = self.result_brower.textCursor()
cursor.movePosition(QTextCursor.End)
self.result_brower.append(text)
self.result_brower.setTextCursor(cursor)
self.result_brower.ensureCursorVisible()
def save_btn_click(self):
directory = QFileDialog.getExistingDirectory(self, "选取文件夹", self.cwd)
self.save_dir.setText(directory)
UI 界面的设计代码,遵循的是和其余 PyQt5 一样的设计范式。依照这样的范式写进去的 UI 代码块集体感觉看起来也比拟好看。
为了避免下载过程比较慢的状况下会导致 UI 界面的主线程间接挂掉,所以在编写下载业务的逻辑时是须要独自应用 QThread 子线程的形式来编写的。这样能够使得业务逻辑和主页面逻辑拆散,就不会产生挂掉的状况产生了。
class DownLoadThread(QThread):
trigger = pyqtSignal(str)
def __init__(self, parent=None):
super(DownLoadThread, self).__init__(parent)
# 初始化日志对象
self.logger = logging.getLogger('英雄联盟皮肤')
logging.basicConfig()
self.logger.setLevel(logging.DEBUG)
self.parent = parent
self.working = True
def __del__(self):
self.working = False
self.wait()
def run(self):
'''
英雄联盟皮肤下载函数
:return:
'''
while self.working == True:
# 结构 useragent 身份设施信息
headers = {"User-Agent": str(UserAgent().random),
}
self.logger.info('生成身份设施信息实现')
self.trigger.emit('生成身份设施信息实现!')
# 在 LOL 的官网通过剖析 champion.js 中蕴含了咱们要用到的英雄 ID 编号,因而,将这个 JS 文件下载下来
champion_js_url = "https://lol.qq.com/biz/hero/champion.js"
# 发送 http 申请、申请地址为这个 JS 文件的地址。就会将其下载下来了。response = requests.get(url=champion_js_url, headers=headers)
self.logger.info('champion.js 文件下载实现')
self.trigger.emit('champion.js 文件下载实现!')
# 获取下载的文本信息
text = response.text
self.logger.info('champion.js 文本信息:' + text)
# 匹配 champion 对象对应的 JSON 数据,该 JSON 数据的第 0 个地位是蕴含英雄 ID 编号的 JSON 数据
hero_json = re.findall(r'champion=(.*?);', text, re.S)[0]
# 将 JSON 数据转换为 dict 字典
hero_dict = json.loads(hero_json)
self.logger.info('英雄 ID 字典信息:' + str(hero_dict))
# 一一英雄信息遍历
for hero_data in hero_dict["data"].items():
# 获取英雄详细信息的 JS 文件
hero_js_url = "http://lol.qq.com/biz/hero/{}.js"
# 发送申请下载该 JS 文件、hero_data[0] 取第 0 位就是英雄 ID
response = requests.get(url=hero_js_url.format(hero_data[0]), headers=headers)
# 获取下载文本
text = response.text
self.logger.info(hero_data[0] + '.js 文本信息:' + text)
self.trigger.emit(hero_data[0] + '.js 文件下载实现!')
skins_dict = json.loads(re.findall("{}=(.*?);".format(hero_data[0]), text, re.S)[0])
self.logger.info('以后英雄皮肤字典:' + str(skins_dict))
# 从字典 skins_dict 获取皮肤列表
skins_list = skins_dict["data"]["skins"]
# 获取英雄名称
hero_name = hero_data[1]["name"]
# 在当前目录上面创立 images 文件夹、以英雄名称作为文件夹名称
os.makedirs(r"./images/{}".format(hero_name), exist_ok=True)
for skin_info in skins_list:
# 初始化皮肤图片地址
skin_pic_url = "https://ossweb-img.qq.com/images/lol/web201310/skin/big{}.jpg"
# 发送下载申请
reponse = requests.get(url=skin_pic_url.format(skin_info["id"]), headers=headers)
try:
self.logger.info('保留门路' + self.parent.save_dir.text().strip())
# 保留皮肤
with open(r""+ self.parent.save_dir.text().strip() +"/{}/{}.jpg".format(hero_name,
skin_info["name"]),
"wb") as f:
f.write(reponse.content)
self.logger.info("{} 下载实现!".format(skin_info["name"]))
self.trigger.emit("{} 下载实现!".format(skin_info["name"]))
except:
self.logger.error(skin_info["name"] + ',下载出现异常. 跳过执行下一个!')
self.trigger.emit(skin_info["name"] + ',下载出现异常. 跳过执行下一个!')
self.sleep(round(random(), 5))
因为下载这一块的业务比拟多,为了不便大家查看。基本上次要的代码块我都写上了正文,须要的小伙伴能够依据本人的需要进行革新。
公众号内回复 ” 英雄联盟皮肤下载器 ” 获取残缺源代码 …
我是 [Python 集中营]、很快乐您看到了最初,我是一个专一于 Python 常识分享的公众号,心愿能够失去您的关注~
【往期精彩】
PyQt5 的敏感词检测工具制作,运营者的福音 …
手绘图片生成器:以雪容融为例一键生成 …
刚刚出炉的冬奥会吉祥物:冰墩墩,附源码 …
最柔美的表格查看插件:tabulate
抖音同款课堂点名零碎,PyQt5 写起来很简略 …