利用Python制作百度图片下载器
更新时间:2022年01月26日 08:30:18 作者:Python 集中营
这篇文章主要介绍了利用Python制作的一个百度图片下载器,可以显示实时的下载进度,文中的示例代码讲解详细,感兴趣的可以跟随小编学习一下
前段时间写了一个百度图片下载器,结果发现有很多人需要使用。说实话之前写的那一款百度图片下载器比较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()
到此这篇关于利用Python制作百度图片下载器的文章就介绍到这了,更多相关Python图片下载器内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
Python深度学习之使用Pytorch搭建ShuffleNetv2
这篇文章主要介绍了Python深度学习之使用Pytorch搭建ShuffleNetv2,文中有非常详细的图文示例,对正在学习python的小伙伴们有非常好的帮助,需要的朋友可以参考下2021-05-05
最新评论