乐趣区

关于python:python-表情包下载器轻松下载上万个表情包斗图不用愁

【浏览全文】

每次和敌人聊天苦于没有表情包,而他人的表情包仿佛是取之不尽、用之不竭。作为一个程序员哪能甘心认输,于是做了一个表情包下载器供大家斗图。

首先,还是介绍一下设计思路吧,和咱们之前做的百度图片下载器 2.0 一样,应用 pyqt5 作为 UI 界面制作的框架,而后就是找一个表情包网站供咱们能够下载很多的表情包。

表情包应用的网站是上面这个,大家也能够应用本人发现的表情包网站做下载。

https://www.fabiaoqing.com/biaoqing/

话不多说,咱们先阐明一下应用到的 python 库有哪些。

UI 界面应用到的 pyqt5 模块是上面这几个,之前也是始终应用这几个库做 UI 界面开发的。

from PyQt5.QtWidgets import *
from PyQt5.QtCore import *
from PyQt5.QtGui import *
import sys
import os

上面是在下载(也能够说是爬虫)表情包时应用到的 python 利用库。

import requests
import re
from urllib.request import urlretrieve
from fake_useragent import UserAgent

将应用到的规范或非规范库筹备好,先来编写 UI 界面,上面就开始咱们的表演了。

class Emoji(QWidget):
    def __init__(self):
        super(Emoji, self).__init__()
        self.init_ui()

    def init_ui(self):
        '''
        初始化 UI 界面布局
        :return:
        '''self.setWindowTitle(' 表情包下载器   公众号:[Python 集中营]')
        self.setWindowIcon(QIcon('表情包图标.png'))
        self.setFixedSize(500, 300)

        grid = QGridLayout()

        self.page_size = QLabel()
        self.page_size.setText('默认每页数量:')

        self.page_size_text = QLineEdit()
        self.page_size_text.setText('45')
        self.page_size_text.setReadOnly(True)

        self.page_num = QLabel()
        self.page_num.setText('设置下载页数:')

        self.page_num_text = QLineEdit()
        self.page_num_text.setPlaceholderText('请输出整数 1~200')
        self.page_num_text.setValidator(QIntValidator(1, 200))

        self.save_dir = QLineEdit()
        self.save_dir.setReadOnly(True)
        self.save_dir.setPlaceholderText('图片存储门路')

        self.save_dir_btn = QPushButton()
        self.save_dir_btn.setText('设置存储门路')
        self.save_dir_btn.clicked.connect(self.save_dir_btn_click)

        self.brower = QTextBrowser()
        self.brower.setPlaceholderText('下载进度后果展现区域...')

        self.start_btn = QPushButton()
        self.start_btn.setText('开始下载表情包')
        self.start_btn.clicked.connect(self.start_btn_click)

        grid.addWidget(self.page_size, 0, 0, 1, 1)
        grid.addWidget(self.page_size_text, 0, 1, 1, 1)
        grid.addWidget(self.page_num, 1, 0, 1, 1)
        grid.addWidget(self.page_num_text, 1, 1, 1, 1)
        grid.addWidget(self.save_dir, 2, 0, 1, 1)
        grid.addWidget(self.save_dir_btn, 2, 1, 1, 1)
        grid.addWidget(self.brower, 3, 0, 1, 2)
        grid.addWidget(self.start_btn, 4, 0, 1, 2)

        self.thread_ = DownloadThread(self)
        self.thread_.finished.connect(self.finished)
        self.thread_.log.connect(self.set_log)

        self.setLayout(grid)

    def save_dir_btn_click(self):
        '''
        设置存储文件门路
        :return:
        '''dir = QFileDialog.getExistingDirectory(self," 抉择文件夹 ", os.getcwd())
        self.save_dir.setText(dir)

    def start_btn_click(self):
        '''
        启动子线程下载表情包
        :return:
        '''
        self.start_btn.setEnabled(False)
        self.thread_.start()
        self.set_log('下载线程曾经启动...')

    def set_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 finished(self, finished):
        if finished is True:
            self.start_btn.setEnabled(True)

编写完 UI 界面当前开始编写用于下载表情包的子线程吧,子线程编写须要继承 pyqt5 中的 QThread 线程来编写。

class DownloadThread(QThread):
    finished = pyqtSignal(bool)
    log = pyqtSignal(str)

    def __init__(self, parent=None):
        super(DownloadThread, self).__init__(parent)
        self.parent = parent
        self.working = True

    def __del__(self):
        self.working = False
        self.wait()

    def run(self):
        self.download()

    def download(self):
        user_agent = UserAgent()
        page_num = int(self.parent.page_num_text.text())
        save_dir = self.parent.save_dir.text()
        for n in range(1, page_num):
            url = 'https://www.fabiaoqing.com/biaoqing/lists/page/{}.html'.format(n)
            headers = {'user-agent': user_agent.random}
            response = requests.get(url, headers=headers)
            repx = re.compile('data-original="(.*?)"title="(.*?)"', re.I)
            texts = repx.findall(response.text)
            for text in texts:
                emoji_url = text[0].split('"src="')[0]
                emoji_name = emoji_url.split('/')[-1]
                urlretrieve(emoji_url,
                            save_dir + '/' + emoji_name)
                self.log.emit(emoji_name + '下载实现!')
        self.log.emit('子线程下载实现!')
        self.finished.emit(True)

最初,应用 main 函数将页面布局退出到利用的主体循环当中,启动整个利用就功败垂成了。

if __name__ == '__main__':
    app = QApplication(sys.argv)
    main = Emoji()
    main.show()
    sys.exit(app.exec_())

将下面的所有的代码块 copy 到开发工具(我用的是 Pycharm)中间接启动就成了。欢送大佬到评论区指导~

【往期精彩】

Python 主动清理电脑垃圾文件,一键启动即可 …

有了 jmespath,解决 python 中的 json 数据就变成了一种享受 …

解锁一个新技能,如何在 Python 代码中应用表情包 …

万能的 list 列表,python 中的堆栈、队列实现全靠它!

该怎么用 pyqt5 来实现数据的增、删、改、查性能 …

介绍一个文本语音神器,几行代码就能搞定!

python 批量主动整顿文件

初学者福利:分享五个收费的 Python 学习网站,放松珍藏吧!

乏味的控制台玩法:一行代码绘制控制台图像!

数据处理小工具:Excel 批量数据文件拆分 / 整合器 …

办公自动化:PDF 文件合并器,将多个 PDF 文件进行合并 …

GUI 猜数字游戏,间接开玩 …

退出移动版