利用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数据可视化Seaborn画热力图

    python数据可视化Seaborn画热力图

    这篇文章主要介绍了数据可视化Seaborn画热力图,热力图的想法其实很简单,用颜色替换数字,下面我们来看看文章对操作过程的具体介绍吧,需要的小伙伴可以参考一下具体内容,希望对你有所帮助
    2022-01-01
  • 如何使用yolov5输出检测到的目标坐标信息

    如何使用yolov5输出检测到的目标坐标信息

    YOLOv5是一系列在 COCO 数据集上预训练的对象检测架构和模型,下面这篇文章主要给大家介绍了关于如何使用yolov5输出检测到的目标坐标信息的相关资料,需要的朋友可以参考下
    2022-03-03
  • 通过Python扫描代码关键字并进行预警的实现方法

    通过Python扫描代码关键字并进行预警的实现方法

    这篇文章主要介绍了通过Python扫描代码关键字并进行预警的实现方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-05-05
  • 人工智能——K-Means聚类算法及Python实现

    人工智能——K-Means聚类算法及Python实现

    这篇文章主要介绍了人工智能——K-Means聚类算法及Python实现,一个能够找到我圈出的这 些点集的算法,就被称为聚类算法,下面就来看看文章具体的介绍吧
    2022-01-01
  • PyTorch、torchvision和Python版本的对应关系

    PyTorch、torchvision和Python版本的对应关系

    使用PyTorch时,选择合适的Python版本是至关重要的,错误的版本组合可能导致各种兼容性问题,本文就来介绍一下PyTorch、torchvision与Python版本匹配,感兴趣的可以了解一下
    2024-03-03
  • python定时任务timeloop库用法实例详解

    python定时任务timeloop库用法实例详解

    有些时候我们需要每隔一段时间就要执行一段程序,或者是往复循环执行某一个任务,下面这篇文章主要给大家介绍了关于python定时任务timeloop库用法的相关资料,需要的朋友可以参考下
    2023-01-01
  • Python2.x版本中maketrans()方法的使用介绍

    Python2.x版本中maketrans()方法的使用介绍

    这篇文章主要介绍了Python2.x版本中maketrans()方法的使用介绍,是Python学习中的基础知识,需要的朋友可以参考下
    2015-05-05
  • 对python抓取需要登录网站数据的方法详解

    对python抓取需要登录网站数据的方法详解

    今天小编就为大家分享一篇对python抓取需要登录网站数据的方法详解,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-05-05
  • 在RedHat系Linux上部署Python的Celery框架的教程

    在RedHat系Linux上部署Python的Celery框架的教程

    这篇文章主要介绍了在RedHat系Linux上部署Python的Celery框架的教程, Celery是一个并行分布框架,拥有良好的I/O性能,需要的朋友可以参考下
    2015-04-04
  • pythotn条件分支与循环详解(3)

    pythotn条件分支与循环详解(3)

    这篇文章主要介绍了Python条件分支和循环用法,结合实例形式较为详细的分析了Python逻辑运算操作符,条件分支语句,循环语句等功能与基本用法,需要的朋友可以参考下
    2021-08-08

最新评论