利用PyQt5制作一個豆瓣電影信息查看器
制作一個查看器可以查看豆瓣前100名電影的信息,當然這個爬取信息比較簡單。所以重點放在 QThread 多線程的應用上面。

QThread 子線程是 PyQt5 自帶的一個線程使用,因為如果使用 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 *
應用操作相關(guān)的模塊。
import sys
先把專門用于信息爬取的獨立線程寫好。新建一個線程類繼承自 QThread,其中最重要的是要寫上 init、del、run這幾個函數(shù)。這幾個函數(shù)對線程類 QThread 里面的函數(shù)重寫的,業(yè)務邏輯是通過 run 函數(shù)實現(xiàn)的。
'''
獨立線程處理信息爬取
'''
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名豆瓣電影詳細信息')
self.start_btn.clicked.connect(self.start_btn_click)
vbox.addWidget(self.start_btn)
self.setLayout(vbox)
文本瀏覽器內(nèi)容保持追加更新的槽函數(shù),將電影信息獲取的實施進度追加到頁面上可以看到。
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ù)在收到主線程的開始命令時來啟動子線程的運行,子線程就會自動去爬取豆瓣上面的排名信息。
def start_btn_click(self):
'''
槽函數(shù):啟動子線程爬取豆瓣電影信息
:return:
'''
self.start_btn.setEnabled(False)
self.thread_.start()
在收到子線程執(zhí)行完成的信息時,將開始按鈕完成可用的狀態(tài)可以點擊再次執(zhí)行。
def finished(self, finished):
'''
槽函數(shù):處理完成時將開始按鈕變成可點擊狀態(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使用sftp實現(xiàn)上傳和下載功能(實例代碼)
在Python中可以使用paramiko模塊中的sftp登陸遠程主機,實現(xiàn)上傳和下載功能。接下來通過本文給大家介紹Python使用sftp實現(xiàn)上傳和下載功能,需要的朋友參考下2017-03-03
Python?flask?框架使用flask-login?模塊的詳細過程
Flask-Login?是一個?Flask?模塊,可以為?Flask?應用程序提供用戶登錄功能,這篇文章主要介紹了Python?flask?框架使用?flask-login?模塊,需要的朋友可以參考下2023-01-01
Python基于Ui控件解析的自動化實現(xiàn)微信(關(guān)鍵詞)自動回復
這篇文章主要為大家介紹了Python基于Ui控件解析的自動化實現(xiàn)微信(關(guān)鍵詞)自動回復,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-11-11

