基于PyQt5制作一个表情包下载器
作者:Python?集中营 发布时间:2022-02-23 13:30:58
标签:Python,PyQt5,表情包,下载
每次和朋友聊天苦于没有表情包,而别人的表情包似乎是取之不尽、用之不竭。作为一个程序员哪能甘愿认输,于是做了一个表情包下载器供大家斗图。
首先,还是介绍一下设计思路吧,和我们之前做的百度图片下载器2.0一样,使用pyqt5作为UI界面制作的框架,然后就是找一个表情包网站供我们可以下载很多的表情包。
表情包使用的网站是这个,大家也可以使用自己发现的表情包网站做下载。
话不多说,我们先说明一下使用到的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)中直接启动就成了。
效果图如下
来源:https://www.cnblogs.com/lwsbc/p/16068760.html


猜你喜欢
- 图像素描特效图像素描特效主要经过以下几个步骤:调用cv.cvtColor()函数将彩色图像灰度化处理;通过cv.GaussianBlur()
- 基于Vue的页面切换左右滑动效果,具体内容如下HTML文本页面:<template> <div id="app&
- 目录一、建立画布二、用plt.subplot函数建立坐标系,并分别绘制折线图和柱状图三、完整代码如下所示四、对应效果图如下所示一、建立画布i
- 模块:xmllibxmllib 是一个非验证的低级语法分析器。应用程序员使用的 xmllib 可以覆盖 XMLParser 类,并提供处理文
- 一、安装对应包在Pycharm的Terminal终端中输入pip install virtualenv,创建一个引入新的虚拟环境的条件。二、
- 通过本接口可以查询圆通快递、申通快递、ems快递、韵达快递等快递单号查询信息,无需其他额外开发,非常方便首先到www.aikuaidi.cn
- 一、 软件配置安装必备爬虫环境软件:python 3.8pip install requestspip install beautifuls
- Mysql InnoDB引擎页目录一、页目录和槽接上一篇,现在知道记录在页中按照主键大小顺序串成了单链表。那么我使用主键查询的时候,最顺其自
- sql server存储过程语法 定义总是很抽象。存储过程其实就是能完成一定操作的一组SQL语句,只不过
- 首先,我们知道一副牌里有54张牌,然后牌里的数字是从 3 - 2 的里面总共有13张牌,然后 4 中花色 分别是 ♠?
- 【1】 以XML 返回 (1)未定义属性的 select logisticsId,logisticsName from LogisticsC
- 1 前言Simhash的算法简单的来说就是,从海量文本中快速搜索和已知simhash相差小于k位的simhash集合,这里每个文本都可以用一
- 本文实例为大家分享了python实现简单俄罗斯方块游戏的具体代码,供大家参考,具体内容如下import pygame,sys,random,
- mysql允许在相同列上创建多个索引,无论是有意还是无意,mysql需要单独维护重复的索引,并且优化器在优化查询的时候也需要逐个地进行考虑,
- 本文实例讲述了python对url格式解析的方法。分享给大家供大家参考。具体分析如下:python针对url格式的解析,可根据指定的完整UR
- 最近要做个从 pdf 文件中抽取文本内容的工具,大概查了一下 python 里可以使用 pdfminer 来实现。下面就看看怎样使用吧。PD
- 我使用“ Web 2.0设计”来形容目前占主导优势的网页设计风格, 很多人用这个词来形容:网络经济的复苏网站和用户之间更高水平的交互或一种社
- 本文实例讲述了django框架中ajax的使用及避开CSRF 验证的方式。分享给大家供大家参考,具体如下:ajax(Asynchronous
- 定义流的作用是使用统一的方式处理文件、网络和数据压缩等共用同一套函数和用法的操作。简单而言,流是具有流式行为的资源对象。因此,流可以线性读写
- 起步要介绍一个非常方便的 Django 扩展包-- django-hosts 。它能够提供在不同的子域名下访问不同的 app。例如,在项目中