利用PyQt5制作一個豆瓣電影信息查看器
制作一個查看器可以查看豆瓣前100名電影的信息,當(dāng)然這個爬取信息比較簡單。所以重點(diǎn)放在 QThread 多線程的應(yīng)用上面。
QThread 子線程是 PyQt5 自帶的一個線程使用,因?yàn)槿绻褂?PyQt5 的主線程去做所有的事情。如果處理速度太慢的情況下主線程就會直接出現(xiàn)卡死狀態(tài)。
網(wǎng)絡(luò)信息提取的相關(guān)模塊有下面這些,主要是一個獲取 Html 信息,另一個解析 Html5 的頁面信息。
import requests # 網(wǎng)絡(luò)請求庫 from bs4 import BeautifulSoup # H5頁面元素解析庫 from fake_useragent import UserAgent # 身份信息生成庫
UI 界面布局相關(guān)的模塊。
from PyQt5.QtWidgets import * from PyQt5.QtGui import * from PyQt5.QtCore import *
應(yīng)用操作相關(guān)的模塊。
import sys
先把專門用于信息爬取的獨(dú)立線程寫好。新建一個線程類繼承自 QThread,其中最重要的是要寫上 init、del、run這幾個函數(shù)。這幾個函數(shù)對線程類 QThread 里面的函數(shù)重寫的,業(yè)務(wù)邏輯是通過 run 函數(shù)實(shí)現(xiàn)的。
''' 獨(dú)立線程處理信息爬取 ''' 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): # 構(gòu)造useragent身份設(shè)備信息 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('信息展示區(qū)域') 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名豆瓣電影詳細(xì)信息') self.start_btn.clicked.connect(self.start_btn_click) vbox.addWidget(self.start_btn) self.setLayout(vbox)
文本瀏覽器內(nèi)容保持追加更新的槽函數(shù),將電影信息獲取的實(shí)施進(jìn)度追加到頁面上可以看到。
def update_log(self, text): ''' 槽函數(shù):向文本瀏覽器中寫入內(nèi)容 :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()
開始按鈕上關(guān)聯(lián)的槽函數(shù),用這個函數(shù)在收到主線程的開始命令時來啟動子線程的運(yùn)行,子線程就會自動去爬取豆瓣上面的排名信息。
def start_btn_click(self): ''' 槽函數(shù):啟動子線程爬取豆瓣電影信息 :return: ''' self.start_btn.setEnabled(False) self.thread_.start()
在收到子線程執(zhí)行完成的信息時,將開始按鈕完成可用的狀態(tài)可以點(diǎn)擊再次執(zhí)行。
def finished(self, finished): ''' 槽函數(shù):處理完成時將開始按鈕變成可點(diǎn)擊狀態(tài) :param finished: :return: ''' if finished is True: self.start_btn.setEnabled(True)
完成后,啟動后臺入口函數(shù),最后看一下入口函數(shù)的寫法和往常是一樣的。
if __name__ == '__main__': ''' 主函數(shù)入口 ''' app = QApplication(sys.argv) main = DouBanUI() main.show() sys.exit(app.exec_())
到此這篇關(guān)于利用PyQt5制作一個豆瓣電影信息查看器的文章就介紹到這了,更多相關(guān)PyQt5電影信息查看器內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
python如何求100以內(nèi)的素?cái)?shù)
在本篇文章里小編給大家分享的是關(guān)于python如何求100以內(nèi)的素?cái)?shù)的方法實(shí)例,需要的朋友們可以學(xué)習(xí)下。2020-05-05Python使用sftp實(shí)現(xiàn)上傳和下載功能(實(shí)例代碼)
在Python中可以使用paramiko模塊中的sftp登陸遠(yuǎn)程主機(jī),實(shí)現(xiàn)上傳和下載功能。接下來通過本文給大家介紹Python使用sftp實(shí)現(xiàn)上傳和下載功能,需要的朋友參考下2017-03-03python計(jì)算機(jī)視覺opencv矩形輪廓頂點(diǎn)位置確定
這篇文章主要為大家介紹了python計(jì)算機(jī)視覺opencv矩形輪廓頂點(diǎn)位置確定,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-05-05Python爬蟲程序架構(gòu)和運(yùn)行流程原理解析
這篇文章主要介紹了Python爬蟲程序架構(gòu)和運(yùn)行流程原理解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-03-03Python?flask?框架使用flask-login?模塊的詳細(xì)過程
Flask-Login?是一個?Flask?模塊,可以為?Flask?應(yīng)用程序提供用戶登錄功能,這篇文章主要介紹了Python?flask?框架使用?flask-login?模塊,需要的朋友可以參考下2023-01-01Python基于Ui控件解析的自動化實(shí)現(xiàn)微信(關(guān)鍵詞)自動回復(fù)
這篇文章主要為大家介紹了Python基于Ui控件解析的自動化實(shí)現(xiàn)微信(關(guān)鍵詞)自動回復(fù),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-11-11