前段时间写了一个百度图片下载器,后果发现有很多人须要应用。说实话之前写的那一款百度图片下载器比拟LOW,明天刚好有工夫就做了一下降级。

残缺源代码的获取形式放在文末了,有须要的间接下载即可。

更新了两个BUG,一个是图片下载达到几千张的时候就没有图片能够下载了。另一个是下载进度不能实时的展现进去不晓得下载到什么水平了。

同样的,咱们先把须要的第三方库导入进来。

'''UI界面相干的库'''from PyQt5.QtWidgets import *from PyQt5.QtCore import *from PyQt5.QtGui import *'''利用操作相干的库'''import sysimport osfrom 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多线程...