利用PyQt5制作一个豆瓣电影信息查看器

 更新时间:2022年01月19日 08:20:09   作者:Python集中营  
这篇文章主要介绍了如何通过PyQt5制作一个查看器,可以查看豆瓣前100名电影的信息,当然这个爬取信息比较简单。感兴趣的小伙伴可以试一试

制作一个查看器可以查看豆瓣前100名电影的信息,当然这个爬取信息比较简单。所以重点放在 QThread 多线程的应用上面。

QThread 子线程是 PyQt5 自带的一个线程使用,因为如果使用 PyQt5 的主线程去做所有的事情。如果处理速度太慢的情况下主线程就会直接出现卡死状态。

网络信息提取的相关模块有下面这些,主要是一个获取 Html 信息,另一个解析 Html5 的页面信息。

import requests  # 网络请求库
from bs4 import BeautifulSoup  # H5页面元素解析库
from fake_useragent import UserAgent  # 身份信息生成库

UI 界面布局相关的模块。

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

应用操作相关的模块。

import sys

先把专门用于信息爬取的独立线程写好。新建一个线程类继承自 QThread,其中最重要的是要写上 initdel、run这几个函数。这几个函数对线程类 QThread 里面的函数重写的,业务逻辑是通过 run 函数实现的。

'''
独立线程处理信息爬取
'''
class DouBanWorker(QThread):
    trigger = pyqtSignal(str)
    finished = pyqtSignal(bool)

    def __init__(self, parent=None):
        super(DouBanWorker, self).__init__(parent)
        self.parent = parent
        self.url = 'https://movie.douban.com/top250?start={}&filter='
        self.working = True

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

    def run(self):
        # 构造useragent身份设备信息
        headers = {
            "User-Agent": str(UserAgent().random),
        }
        for page in range(4):
            url = self.url.format(page * 25)
            response = requests.get(url, headers=headers)
            bs = BeautifulSoup(response.text, 'html.parser')
            movie_list = bs.find_all('div', class_='item')
            for movie in movie_list:
                movie_seq = movie.find('em').text
                movie_name = movie.find('span').text
                movie_score = movie.find("span", class_='rating_num').text
                movie_inst = movie.find("span", class_='inq').text
                movie_link = movie.find('a')['href']
                self.trigger.emit('\n')
                self.trigger.emit('排名:' + movie_seq + '\n')
                self.trigger.emit('名称:' + movie_name + '\n')
                self.trigger.emit('评分:' + movie_score + '\n')
                self.trigger.emit('描述:' + movie_inst + '\n')
                movie_link = "<font color='blue'>" + movie_link + "</font>"
                self.trigger.emit('链接:' + movie_link + '\n')
        self.finished.emit(True)

主界面的 UI 布局信息比较简单,主要是一个文本浏览器和一个开始的按钮组成的。

def init_ui(self):
        '''
        初始化UI界面布局
        :return:
        '''
        self.setWindowTitle('豆瓣电影排名')
        self.setWindowIcon(QIcon('电影.ico'))
        self.resize(400, 300)

        vbox = QVBoxLayout()

        self.result_brower = QTextBrowser()
        self.result_brower.setFont(QFont('宋体', 8))
        self.result_brower.setReadOnly(True)
        self.result_brower.setPlaceholderText('信息展示区域')
        self.result_brower.ensureCursorVisible()

        vbox.addWidget(self.result_brower)

        self.thread_ = DouBanWorker(self)
        self.thread_.trigger.connect(self.update_log)
        self.thread_.finished.connect(self.finished)

        self.start_btn = QPushButton()
        self.start_btn.setText('获取前100名豆瓣电影详细信息')
        self.start_btn.clicked.connect(self.start_btn_click)

        vbox.addWidget(self.start_btn)

        self.setLayout(vbox)

文本浏览器内容保持追加更新的槽函数,将电影信息获取的实施进度追加到页面上可以看到。

 def update_log(self, text):
        '''
        槽函数:向文本浏览器中写入内容
        :param text:
        :return:
        '''
        cursor = self.result_brower.textCursor()
        cursor.movePosition(QTextCursor.End)
        self.result_brower.append(text)
        self.result_brower.setTextCursor(cursor)
        self.result_brower.ensureCursorVisible()

开始按钮上关联的槽函数,用这个函数在收到主线程的开始命令时来启动子线程的运行,子线程就会自动去爬取豆瓣上面的排名信息。

def start_btn_click(self):
        '''
        槽函数:启动子线程爬取豆瓣电影信息
        :return:
        '''
        self.start_btn.setEnabled(False)
        self.thread_.start()

在收到子线程执行完成的信息时,将开始按钮完成可用的状态可以点击再次执行。

  def finished(self, finished):
        '''
        槽函数:处理完成时将开始按钮变成可点击状态
        :param finished:
        :return:
        '''
        if finished is True:
            self.start_btn.setEnabled(True)

完成后,启动后台入口函数,最后看一下入口函数的写法和往常是一样的。

if __name__ == '__main__':
    '''
    主函数入口
    '''
    app = QApplication(sys.argv)
    main = DouBanUI()
    main.show()
    sys.exit(app.exec_())

到此这篇关于利用PyQt5制作一个豆瓣电影信息查看器的文章就介绍到这了,更多相关PyQt5电影信息查看器内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • python如何求100以内的素数

    python如何求100以内的素数

    在本篇文章里小编给大家分享的是关于python如何求100以内的素数的方法实例,需要的朋友们可以学习下。
    2020-05-05
  • Python使用sftp实现上传和下载功能(实例代码)

    Python使用sftp实现上传和下载功能(实例代码)

    在Python中可以使用paramiko模块中的sftp登陆远程主机,实现上传和下载功能。接下来通过本文给大家介绍Python使用sftp实现上传和下载功能,需要的朋友参考下
    2017-03-03
  • 简单介绍Python的轻便web框架Bottle

    简单介绍Python的轻便web框架Bottle

    这篇文章主要介绍了Python的轻便web框架Bottle,因其注重轻便的设计,与Flask一样,Bottle框架的人气同样也非常高,需要的朋友可以参考下
    2015-04-04
  • spark编程python实例解读

    spark编程python实例解读

    这篇文章主要介绍了spark编程python实例解读,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-02-02
  • python计算机视觉opencv矩形轮廓顶点位置确定

    python计算机视觉opencv矩形轮廓顶点位置确定

    这篇文章主要为大家介绍了python计算机视觉opencv矩形轮廓顶点位置确定,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-05-05
  • Python爬虫程序架构和运行流程原理解析

    Python爬虫程序架构和运行流程原理解析

    这篇文章主要介绍了Python爬虫程序架构和运行流程原理解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-03-03
  • Python flask 框架使用flask-login 模块的详细过程

    Python flask 框架使用flask-login 模块的详细过程

    Flask-Login 是一个 Flask 模块,可以为 Flask 应用程序提供用户登录功能,这篇文章主要介绍了Python flask 框架使用 flask-login 模块,需要的朋友可以参考下
    2023-01-01
  • django用户登录验证的完整示例代码

    django用户登录验证的完整示例代码

    这篇文章主要给大家介绍了关于django用户登录验证的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用Spring django具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-07-07
  • Python基于Ui控件解析的自动化实现微信(关键词)自动回复

    Python基于Ui控件解析的自动化实现微信(关键词)自动回复

    这篇文章主要为大家介绍了Python基于Ui控件解析的自动化实现微信(关键词)自动回复,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-11-11
  • Flask框架的学习指南之用户登录管理

    Flask框架的学习指南之用户登录管理

    本文是Flask框架的学习指南系列文章的第三篇,主要给大家讲述的是制作flask的登陆管理模块,有需要的小伙伴可以参考下
    2016-11-11

最新评论