前段时间写了一个百度图片下载器,后果发现有很多人须要应用。说实话之前写的那一款百度图片下载器比拟 LOW,明天刚好有工夫就做了一下降级。
残缺源代码的获取形式放在文末了,有须要的间接下载即可。
更新了两个 BUG,一个是图片下载达到几千张的时候就没有图片能够下载了。另一个是下载进度不能实时的展现进去不晓得下载到什么水平了。
同样的,咱们先把须要的第三方库导入进来。
'''UI 界面相干的库'''
from PyQt5.QtWidgets import *
from PyQt5.QtCore import *
from PyQt5.QtGui import *
'''利用操作相干的库'''
import sys
import os
from scripy_images import ScripyImages
UI 界面在原来的根底下面减少了文本浏览器能够实时的查看下载进度,还有减少了每一页下载的图片数量的管制让下载数据更加准确。
def init_ui(self):
self.setWindowTitle('百度图片下载器 2.0 公众号:[Python 集中营]')
self.setWindowIcon(QIcon('下载.ico'))
self.setFixedSize(550, 300)
grid = QGridLayout()
self.page_label = QLabel()
self.page_label.setText('设置爬取页数:')
self.page_line_text = QLineEdit()
self.page_line_text.setPlaceholderText('输出整数')
self.page_line_text.setValidator(QIntValidator(1, 99))
self.page_line_text.setFocus()
self.page_num_label = QLabel()
self.page_num_label.setText('每页爬取数量:')
self.page_num_text = QSpinBox()
self.page_num_text.setRange(50, 100)
self.page_num_text.setSingleStep(10)
self.page_num_text.setWrapping(True)
self.keyword_label = QLabel()
self.keyword_label.setText('设置图关键字:')
self.keyword_line_text = QLineEdit()
self.keyword_line_text.setValidator(QRegExpValidator(QRegExp('[\u4E00-\u9FA5]+')))
self.keyword_line_text.setMaxLength(6)
self.keyword_line_text.setPlaceholderText('输出汉字')
self.file_path = QLineEdit()
self.file_path.setPlaceholderText('自定义文件门路')
self.file_path.setReadOnly(True)
self.file_path_button = QPushButton()
self.file_path_button.setText('自定义门路')
self.file_path_button.clicked.connect(self.file_path_click)
self.request_button = QPushButton()
self.request_button.setText('疾速开始抓取图片')
self.request_button.clicked.connect(self.download_image)
self.brower = QTextBrowser()
self.brower.setPlaceholderText('抓取进度后果展现...')
grid.addWidget(self.page_label, 0, 0, 1, 1)
grid.addWidget(self.page_line_text, 0, 1, 1, 2)
grid.addWidget(self.page_num_label, 1, 0, 1, 1)
grid.addWidget(self.page_num_text, 1, 1, 1, 2)
grid.addWidget(self.keyword_label, 2, 0, 1, 1)
grid.addWidget(self.keyword_line_text, 2, 1, 1, 2)
grid.addWidget(self.file_path, 3, 0, 1, 2)
grid.addWidget(self.file_path_button, 3, 2, 1, 1)
grid.addWidget(self.brower, 4, 0, 1, 3)
grid.addWidget(self.request_button, 5, 0, 1, 3)
self.thread_ = ScripyImages(self)
self.thread_.trigger.connect(self.update_log)
self.thread_.finished.connect(self.finished)
self.setLayout(grid)
减少管制向文本浏览器中实时写入数据的槽函数。
def update_log(self, text):
'''
槽函数:向文本浏览器中写入内容
:param text:
:return:
'''
cursor = self.brower.textCursor()
cursor.movePosition(QTextCursor.End)
self.brower.append(text)
self.brower.setTextCursor(cursor)
self.brower.ensureCursorVisible()
优化了图片的下载过程,应用专门的子线程来解决图片下载的局部。
def download_image(self):
self.request_button.setEnabled(False)
self.thread_.start()
图片下载的线程解决逻辑在残缺的源代码局部能够下载,这里就不展现代码块了。
公众号内回复 ” 百度图片下载器 2.0″ 获取残缺源代码。
我是 [Python 集中营]、很快乐您看到了最初,我是一个专一于 Python 常识分享的公众号,心愿能够失去您的关注~
【往期精彩】
gif 动静图片生成器,多张图片组合后生成动图 …
python 几个常见的数据处理操作,一行代码就能实现!
过年了,用 PyQt5 生成一副春联吧 …
记录一下 python 中的十大 % 占位符对应的格式化 …
PyQt5 UI 制作一个豆瓣电影信息查看器,初识 QThread 多线程 …