【浏览全文】

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

首先,还是介绍一下设计思路吧,和咱们之前做的百度图片下载器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 sysimport os

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

import requestsimport refrom urllib.request import urlretrievefrom 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猜数字游戏,间接开玩...