关于python:百度图片下载器20

5次阅读

共计 2824 个字符,预计需要花费 8 分钟才能阅读完成。

前段时间写了一个百度图片下载器,后果发现有很多人须要应用。说实话之前写的那一款百度图片下载器比拟 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 多线程 …

正文完
 0