基于Python制作天眼查小程序的示例代碼
今天我們一起來(lái)制作一個(gè)天眼查GUI程序,開宗明義,我們先來(lái)看下最終的效果
這次的GUI程序,我們使用的框架是PyQt5
,該框架擁有比tkinter
更為豐富的內(nèi)置組件,在界面美化方面,貌似也更勝一籌!
從上圖也可以看出,我們的目標(biāo)還是蠻遠(yuǎn)大的,最終我們希望可以完成一個(gè)工具集合,把我們?nèi)粘.?dāng)中常用的功能都集成的該GUI程序中,比如天眼查公司信息,知乎用戶知識(shí)圖譜,B視頻彈幕抓取等等。
好了,今天我們先完成天眼查的功能吧~
界面搭建
大家也都看到了,本GUI程序的整體界面還是不丑的(原諒我只敢用不丑兩個(gè)字),雖然可能目前僅僅是看起來(lái)不丑,但是背后的美化工作還是非常繁瑣的。
這里蘿卜哥也是借鑒了網(wǎng)上大神的基礎(chǔ)代碼,州的先生在PyQt5
方面有頗多造詣,大家也可以多多關(guān)注哦!
整體布局
首先我們來(lái)大致看一下界面的布局情況
界面總體分為左側(cè)的 Widget 和右側(cè)的 Widget
左側(cè) Widget 部分代碼
????def?leftWidget(self): ????????self.left_close?=?QtWidgets.QPushButton(qtawesome.icon('fa.close',?color='white'),?"")?#?關(guān)閉按鈕 ????????self.left_visit?=?QtWidgets.QPushButton(qtawesome.icon('fa.circle-o',?color='white'),?"")?#?空白按鈕 ????????self.left_mini?=?QtWidgets.QPushButton(qtawesome.icon('fa.minus',?color='white'),?"")?#?最小化按鈕 ????????self.left_label_1?=?QtWidgets.QPushButton("網(wǎng)絡(luò)抓取") ????????self.left_label_1.setObjectName('left_label') ????????self.left_label_2?=?QtWidgets.QPushButton("待開發(fā)") ????????self.left_label_2.setObjectName('left_label') ????????self.left_label_3?=?QtWidgets.QPushButton("聯(lián)系與幫助") ????????self.left_label_3.setObjectName('left_label') ????????self.left_button_1?=?QtWidgets.QPushButton(qtawesome.icon('fa.eye',?color='white'),?"天眼查") ????????self.left_button_1.setObjectName('left_button') ????????self.left_button_2?=?QtWidgets.QPushButton(qtawesome.icon('fa.bullhorn',?color='white'),?"知乎") ????????self.left_button_2.setObjectName('left_button') ????????self.left_button_3?=?QtWidgets.QPushButton(qtawesome.icon('fa.bold',?color='white'),?"B站") ????????self.left_button_3.setObjectName('left_button') ????????...
左側(cè)部分,主要是一些功能按鈕的布局,我們可以在一個(gè)函數(shù)當(dāng)中完成這些
對(duì)于右側(cè) Widget,我們需要區(qū)分不同的功能,比如天眼查代碼
????def?tianyanchaWidget(self): ????????self.left_button_widget_1?=?QtWidgets.QWidget() ????????self.left_button_widget_1.setGeometry(QtCore.QRect(10,?10,?591,?461)) ????????self.left_button_widget_1.setObjectName("left_button_1") ????????self.gridLayout?=?QtWidgets.QGridLayout(self.left_button_widget_1) ????????self.gridLayout.setContentsMargins(0,?0,?0,?0) ????????self.gridLayout.setObjectName("gridLayout") ????????self.lineEdit?=?QtWidgets.QLineEdit() ????????self.lineEdit.setObjectName("lineEdit") ????????self.gridLayout.addWidget(self.lineEdit,?0,?1,?1,?7) ????????self.pushButton?=?QtWidgets.QPushButton(qtawesome.icon('fa.search',?color='black'),?"Search") ????????self.pushButton.setObjectName("pushButton") ????????self.gridLayout.addWidget(self.pushButton,?0,?0,?1,?1) ????????#?下載按鈕 ????????self.downButton?=?QtWidgets.QPushButton(qtawesome.icon('fa.download',?color='black'),?"Download") ????????self.downButton.setObjectName("downButton") ????????self.gridLayout.addWidget(self.downButton,?0,?8,?1,?1) ????????self.textEdit?=?QtWidgets.QTextEdit(self.left_button_widget_1) ????????self.textEdit.setObjectName("textEdit") ????????self.gridLayout.addWidget(self.textEdit,?3,?0,?1,?9) ????????self.right_layout.addWidget(self.left_button_widget_1,?0,?0,?1,?9)
為不同的功能設(shè)置不同的QtWidgets.QWidget()
,這樣方便我們后面點(diǎn)擊左側(cè)不同按鈕時(shí),右側(cè)界面跟著切換
大致的布局就是這些,當(dāng)然還有一些界面美化的工作,我們簡(jiǎn)單看下
界面美化
美化工作我們主要使用函數(shù)setStyleSheet
來(lái)進(jìn)行,其實(shí)也就是為各個(gè)組件添加樣式,類似于Web應(yīng)用的CSS
優(yōu)化函數(shù)
????def?leftStyle(self): ????????self.left_close.setFixedSize(15,?15)?#?設(shè)置關(guān)閉按鈕的大小 ????????self.left_visit.setFixedSize(15,?15)?#?設(shè)置按鈕大小 ????????self.left_mini.setFixedSize(15,?15)?#?設(shè)置最小化按鈕大小 ????????self.left_close.setStyleSheet( ????????'''QPushButton{background:#F76677;border-radius:5px;}QPushButton:hover{background:red;}''') ????????self.left_visit.setStyleSheet( ????????'''QPushButton{background:#F7D674;border-radius:5px;}QPushButton:hover{background:yellow;}''') ????????self.left_mini.setStyleSheet( ????????'''QPushButton{background:#6DDF6D;border-radius:5px;}QPushButton:hover{background:green;}''') ????????self.left_widget.setStyleSheet(''' ????????QPushButton{border:none;color:white;} ????????QPushButton#left_label{ ????????border:none; ????????border-bottom:1px?solid?white; ????????font-size:18px; ????????font-weight:700; ????????font-family:?"Helvetica?Neue",?Helvetica,?Arial,?sans-serif; ????????} ????????QPushButton#left_button:hover{border-left:4px?solid?red;font-weight:700;} ????????QWidget#left_widget{ ????????background:gray; ????????border-top:1px?solid?white; ????????border-bottom:1px?solid?white; ????????border-left:1px?solid?white; ????????border-top-left-radius:10px; ????????border-bottom-left-radius:10px; ????????} ????????''')
可以看到,美化的過(guò)程也確實(shí)就是添加樣式的過(guò)程,如果對(duì)于CSS比較熟悉的小伙伴,在這里應(yīng)該也不陌生吧
好了,界面部分大致就是這些,下面我們來(lái)看看天眼查信息的爬取部分
天眼查爬蟲
天眼查相信大家都比較熟悉,一個(gè)用于查詢公司或者個(gè)人相關(guān)信息的網(wǎng)站。
獲取信息
由于該網(wǎng)站的很多信息也都是爬蟲獲取的,所以其反爬手段也是極其高明,這里我們沒有對(duì)Web端進(jìn)行爬取,而是選擇了小程序,通過(guò)對(duì)天眼查小程序的抓包,可以獲取到其請(qǐng)求公司的時(shí)候所使用的header
以及對(duì)應(yīng)的URL
,我們拿到之后通過(guò)Postman
進(jìn)行測(cè)試如下
我們只需要在請(qǐng)求上面的URL
的時(shí)候,在header
當(dāng)中攜帶對(duì)應(yīng)的Authorization
信息就可以,而且經(jīng)過(guò)測(cè)試,該Authorization
信息的過(guò)期時(shí)間非常長(zhǎng),長(zhǎng)到我還沒有摸清楚到底多久會(huì)過(guò)期,反正獲取了一個(gè)之后,就一直可以使用,真好!
代碼編寫
拿到請(qǐng)求方法時(shí)候,我們就可以編寫代碼了,這反而是比較簡(jiǎn)單的一步
????def?query(self): ????????company_name?=?self.lineEdit.text() ????????if?not?company_name: ????????????QMessageBox.information(self,?"Error",?"公司名稱不能為空", ????????????????????????????????????QMessageBox.Yes) ????????????return ????????#?獲取基本信息 ????????headers?=?{ ????????????'User-Agent':?'Mozilla/5.0?(Macintosh;?Intel?Mac?OS?X?10_15_7)?AppleWebKit/537.36?(KHTML,?like?Gecko)?Chrome/97.0.4692.71?Safari/537.36', ????????????'version':?'TYC-XCX-WX', ????????????'Host':?'api9.tianyancha.com', ????????????'Authorization':?'0###2088812821785822###1661951360266###fec9a76739ba0efd0a7f8b0b4a9a0074', ????????} ????????url?=?f'https://api9.tianyancha.com/services/v3/search/sNorV3/{company_name}' ????????response?=?requests.get(url,?headers=headers) ????????response_json,?data?=?response.json(),?dict() ????????if?response_json['state']?==?'ok': ????????????data?=?response_json.get('data',?{}) ????????...
上面的函數(shù)會(huì)返回處理過(guò)的公司信息數(shù)據(jù),然后我們通過(guò) Button 的綁定事件來(lái)調(diào)用該函數(shù),并把數(shù)據(jù)輸出到組件textEdit
中
self.pushButton.clicked.connect(self.query) self.textEdit.setText(company_info_str)
至此,我們這個(gè)天眼查工具就完成了~
結(jié)果展示
下面我們來(lái)看看最終的效果吧
到此這篇關(guān)于基于Python制作天眼查小程序的示例代碼的文章就介紹到這了,更多相關(guān)Python天眼查內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
python測(cè)試mysql寫入性能完整實(shí)例
這篇文章主要介紹了python測(cè)試mysql寫入性能完整實(shí)例,具有一定借鑒價(jià)值,需要的朋友可以參考下2018-01-01python使用pandas實(shí)現(xiàn)數(shù)據(jù)分割實(shí)例代碼
這篇文章主要介紹了python使用pandas實(shí)現(xiàn)數(shù)據(jù)分割實(shí)例代碼,介紹了使用pandas實(shí)現(xiàn)對(duì)dataframe格式的數(shù)據(jù)分割成時(shí)間跨度相等的數(shù)據(jù)塊,分享了相關(guān)代碼示例,小編覺得還是挺不錯(cuò)的,具有一定借鑒價(jià)值,需要的朋友可以參考下2018-01-01基于python實(shí)現(xiàn)微信好友數(shù)據(jù)分析(簡(jiǎn)單)
本文主要介紹利用網(wǎng)頁(yè)端微信獲取數(shù)據(jù),實(shí)現(xiàn)個(gè)人微信好友數(shù)據(jù)的獲取,并進(jìn)行一些簡(jiǎn)單的數(shù)據(jù)分析,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2020-02-02Python實(shí)現(xiàn)采集網(wǎng)站ip代理并檢測(cè)是否可用
這篇文章主要介紹了如何利用Python爬蟲實(shí)現(xiàn)采集網(wǎng)站ip代理,并檢測(cè)IP代理是否可用。文中的示例代碼講解詳細(xì),感興趣的可以試一試2022-01-01