日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

Python 制作天眼查小程序

發(fā)布時間:2024/3/24 python 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Python 制作天眼查小程序 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

這是「進擊的Coder」的第 788?篇技術分享

作者:蘿卜大雜燴

來源:蘿卜大雜燴

閱讀本文大概需要 9 分鐘。

今天我們一起來制作一個天眼查 GUI 程序,開宗明義,我們先來看下最終的效果

這次的 GUI 程序,我們使用的框架是PyQt5,該框架擁有比tkinter更為豐富的內置組件,在界面美化方面,貌似也更勝一籌!

從上圖也可以看出,我們的目標還是蠻遠大的,最終我們希望可以完成一個工具集合,把我們日常當中常用的功能都集成的該 GUI 程序中,比如天眼查公司信息,知乎用戶知識圖譜,B 視頻彈幕抓取等等。

好了,今天我們先完成天眼查的功能吧~

界面搭建

大家也都看到了,本 GUI 程序的整體界面還是不丑的(原諒我只敢用不丑兩個字),雖然可能目前僅僅是看起來不丑,但是背后的美化工作還是非常繁瑣的。

這里蘿卜哥也是借鑒了網上大神的基礎代碼,州的先生[1]在PyQt5方面有頗多造詣,大家也可以多多關注哦!

整體布局

首先我們來大致看一下界面的布局情況

界面總體分為左側的 Widget 和右側的 Widget

左側 Widget 部分代碼

def?leftWidget(self):self.left_close?=?QtWidgets.QPushButton(qtawesome.icon('fa.close',?color='white'),?"")?#?關閉按鈕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("網絡抓取")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("聯系與幫助")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')...

左側部分,主要是一些功能按鈕的布局,我們可以在一個函數當中完成這些

對于右側 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)

為不同的功能設置不同的QtWidgets.QWidget(),這樣方便我們后面點擊左側不同按鈕時,右側界面跟著切換

大致的布局就是這些,當然還有一些界面美化的工作,我們簡單看下

界面美化

美化工作我們主要使用函數setStyleSheet來進行,其實也就是為各個組件添加樣式,類似于 Web 應用的 CSS

優(yōu)化函數

def?leftStyle(self):self.left_close.setFixedSize(15,?15)?#?設置關閉按鈕的大小self.left_visit.setFixedSize(15,?15)?#?設置按鈕大小self.left_mini.setFixedSize(15,?15)?#?設置最小化按鈕大小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;}''')

可以看到,美化的過程也確實就是添加樣式的過程,如果對于 CSS 比較熟悉的小伙伴,在這里應該也不陌生吧

好了,界面部分大致就是這些,下面我們來看看天眼查信息的爬取部分

天眼查爬蟲

天眼查相信大家都比較熟悉,一個用于查詢公司或者個人相關信息的網站。

獲取信息

由于該網站的很多信息也都是爬蟲獲取的,所以其反爬手段也是極其高明,這里我們沒有對 Web 端進行爬取,而是選擇了小程序,通過對天眼查小程序的抓包,可以獲取到其請求公司的時候所使用的header以及對應的URL,我們拿到之后通過Postman進行測試如下

?

由于本篇文章重點不是爬蟲,所以具體的爬取過程沒有詳細給出,如果小伙伴們需要,本篇點贊超過?10?個,就安排出一篇文章詳細寫一下!

我們只需要在請求上面的URL的時候,在header當中攜帶對應的Authorization信息就可以,而且經過測試,該Authorization信息的過期時間非常長,長到我還沒有摸清楚到底多久會過期,反正獲取了一個之后,就一直可以使用,真好!

代碼編寫

拿到請求方法時候,我們就可以編寫代碼了,這反而是比較簡單的一步

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',?{})...

上面的函數會返回處理過的公司信息數據,然后我們通過 Button 的綁定事件來調用該函數,并把數據輸出到組件textEdit中

self.pushButton.clicked.connect(self.query) self.textEdit.setText(company_info_str)

至此,我們這個天眼查工具就完成了~

結果展示

下面我們來看看最終的效果吧

持續(xù)關注,我們后面再繼續(xù)集成開發(fā)其他功能哦!

好了,這就是今天分享的全部內容,喜歡就點個吧~

參考資料

[1]

州的先生的網站: https://zmister.com/

End

崔慶才的新書《Python3網絡爬蟲開發(fā)實戰(zhàn)(第二版)》已經正式上市了!書中詳細介紹了零基礎用 Python 開發(fā)爬蟲的各方面知識,同時相比第一版新增了 JavaScript 逆向、Android 逆向、異步爬蟲、深度學習、Kubernetes 相關內容,?同時本書已經獲得 Python 之父 Guido 的推薦,目前本書正在七折促銷中!

內容介紹:《Python3網絡爬蟲開發(fā)實戰(zhàn)(第二版)》內容介紹

掃碼購買

好文和朋友一起看~

總結

以上是生活随笔為你收集整理的Python 制作天眼查小程序的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。