PyQt5+requests實(shí)現(xiàn)車票查詢工具
PyQt5+requests實(shí)現(xiàn)一個(gè)車票查詢工具,供大家參考,具體內(nèi)容如下
結(jié)構(gòu)圖

效果圖

思路
1、search(QPushButton)點(diǎn)擊信號(hào)(clicked)連接到自定義的槽函數(shù)(event.search)
2、槽函數(shù)(event.search)接收四個(gè)參數(shù):QTableWidget對(duì)象的引用、兩個(gè)QLabel中的內(nèi)容(站臺(tái)名稱)、QDateEdit格式化日期
3、槽函數(shù)(event.search)調(diào)用爬蟲類(TrainService)獲取車次信息,添加到QTableWidget對(duì)象中。
代碼
1、ui.py(ui界面)
# -*- coding: utf-8 -*-
# Form implementation generated from reading ui file 'E:\Python\Qt\ui_0.ui'
#
# Created by: PyQt5 UI code generator 5.11.2
#
# WARNING! All changes made in this file will be lost!
from PyQt5 import QtCore, QtGui, QtWidgets
from Event import EventClass
class Ui_MainWindow(object):
def setupUi(self, MainWindow):
event=EventClass()
MainWindow.setObjectName("MainWindow")
MainWindow.resize(793, 604)
MainWindow.setStyleSheet("font: 10pt \"Microsoft YaHei UI\";")
self.centralwidget = QtWidgets.QWidget(MainWindow)
self.centralwidget.setObjectName("centralwidget")
self.widget = QtWidgets.QWidget(self.centralwidget)
self.widget.setGeometry(QtCore.QRect(0, 0, 791, 43))
self.widget.setObjectName("widget")
self.horizontalLayout = QtWidgets.QHBoxLayout(self.widget)
self.horizontalLayout.setSizeConstraint(QtWidgets.QLayout.SetNoConstraint)
self.horizontalLayout.setContentsMargins(10, 1, 1, 3)
self.horizontalLayout.setSpacing(15)
self.horizontalLayout.setObjectName("horizontalLayout")
self.label = QtWidgets.QLabel(self.widget)
self.label.setObjectName("label")
self.horizontalLayout.addWidget(self.label)
self.lineEdit = QtWidgets.QLineEdit(self.widget)
self.lineEdit.setMaximumSize(QtCore.QSize(742, 16777215))
self.lineEdit.setObjectName("lineEdit")
self.horizontalLayout.addWidget(self.lineEdit)
self.label_2 = QtWidgets.QLabel(self.widget)
self.label_2.setObjectName("label_2")
self.horizontalLayout.addWidget(self.label_2)
self.lineEdit_2 = QtWidgets.QLineEdit(self.widget)
self.lineEdit_2.setObjectName("lineEdit_2")
self.horizontalLayout.addWidget(self.lineEdit_2)
self.dateEdit = QtWidgets.QDateEdit(self.widget)
self.dateEdit.setDate(QtCore.QDate(2019, 1, 1))
self.dateEdit.setObjectName("dateEdit")
self.horizontalLayout.addWidget(self.dateEdit)
self.pushButton = QtWidgets.QPushButton(self.widget)
self.pushButton.setObjectName("pushButton")
self.horizontalLayout.addWidget(self.pushButton)
self.scrollArea = QtWidgets.QScrollArea(self.centralwidget)
self.scrollArea.setGeometry(QtCore.QRect(0, 40, 791, 561))
self.scrollArea.setWidgetResizable(True)
self.scrollArea.setObjectName("scrollArea")
self.scrollAreaWidgetContents = QtWidgets.QWidget()
self.scrollAreaWidgetContents.setGeometry(QtCore.QRect(0, 0, 789, 559))
self.scrollAreaWidgetContents.setObjectName("scrollAreaWidgetContents")
self.tableWidget = QtWidgets.QTableWidget(self.scrollAreaWidgetContents)
self.tableWidget.setGeometry(QtCore.QRect(0, 0, 791, 561))
sizePolicy = QtWidgets.QSizePolicy(QtWidgets.QSizePolicy.Expanding, QtWidgets.QSizePolicy.Expanding)
sizePolicy.setHorizontalStretch(0)
sizePolicy.setVerticalStretch(0)
sizePolicy.setHeightForWidth(self.tableWidget.sizePolicy().hasHeightForWidth())
self.tableWidget.setSizePolicy(sizePolicy)
self.tableWidget.setBaseSize(QtCore.QSize(0, 0))
self.tableWidget.setObjectName("tableWidget")
self.tableWidget.setColumnCount(5)
self.tableWidget.setRowCount(0)
item = QtWidgets.QTableWidgetItem()
self.tableWidget.setHorizontalHeaderItem(0, item)
item = QtWidgets.QTableWidgetItem()
self.tableWidget.setHorizontalHeaderItem(1, item)
item = QtWidgets.QTableWidgetItem()
self.tableWidget.setHorizontalHeaderItem(2, item)
item = QtWidgets.QTableWidgetItem()
self.tableWidget.setHorizontalHeaderItem(3, item)
item = QtWidgets.QTableWidgetItem()
self.tableWidget.setHorizontalHeaderItem(4, item)
self.tableWidget.horizontalHeader().setDefaultSectionSize(155)
self.tableWidget.verticalHeader().setDefaultSectionSize(47)
self.tableWidget.verticalHeader().setMinimumSectionSize(45)
self.line = QtWidgets.QFrame(self.scrollAreaWidgetContents)
self.line.setGeometry(QtCore.QRect(0, 23, 784, 31))
self.line.setToolTipDuration(0)
self.line.setLineWidth(1)
self.line.setFrameShape(QtWidgets.QFrame.HLine)
self.line.setFrameShadow(QtWidgets.QFrame.Sunken)
self.line.setObjectName("line")
self.scrollArea.setWidget(self.scrollAreaWidgetContents)
MainWindow.setCentralWidget(self.centralwidget)
self.retranslateUi(MainWindow)
self.pushButton.clicked.connect(lambda :event.search(self.tableWidget, self.lineEdit.text(), self.lineEdit_2.text(), self.dateEdit.date().toPyDate()))
QtCore.QMetaObject.connectSlotsByName(MainWindow)
def retranslateUi(self, MainWindow):
_translate = QtCore.QCoreApplication.translate
MainWindow.setWindowTitle(_translate("MainWindow", "MainWindow"))
self.label.setText(_translate("MainWindow", "From"))
self.label_2.setText(_translate("MainWindow", "To"))
self.pushButton.setText(_translate("MainWindow", "search"))
item = self.tableWidget.horizontalHeaderItem(0)
item.setText(_translate("MainWindow", "車次"))
item = self.tableWidget.horizontalHeaderItem(1)
item.setText(_translate("MainWindow", "出發(fā)時(shí)間"))
item = self.tableWidget.horizontalHeaderItem(2)
item.setText(_translate("MainWindow", "到站時(shí)間"))
item = self.tableWidget.horizontalHeaderItem(3)
item.setText(_translate("MainWindow", "硬臥"))
item = self.tableWidget.horizontalHeaderItem(4)
item.setText(_translate("MainWindow", "硬座"))
if __name__ == "__main__":
import sys
app = QtWidgets.QApplication(sys.argv)
MainWindow = QtWidgets.QMainWindow()
ui = Ui_MainWindow()
ui.setupUi(MainWindow)
MainWindow.show()
sys.exit(app.exec_())
2、EventClass.py(自定義槽函數(shù)類)
#coding:u8
import time
from PyQt5.QtWidgets import QTableWidgetItem
from TrainService import TrainService
class EventClass(object):
def __init__(self):
self.trainService=TrainService()
pass
def search(self, table, From="北京", To="上海", Date=time.strftime("%Y-%m-%d", time.localtime())):
print("【{}】 form {} to {}".format(Date, From, To))
train_list=self.trainService.crawlTrainMess(From, To, Date)
print(table)
table.setRowCount(len(train_list))
for row, item in enumerate(train_list):
for col, i in enumerate(item):
if i is "":
i="0"
table.setItem(row, col, QTableWidgetItem(i))
pass
3、TrainService.py(爬蟲類)
#coding_url:u8
import requests
import json
class TrainService(object):
def __init__(self):
with open("code.json", 'r') as file:
code=eval(file.read())
self.code=code
self.code_url="https://kyfw.12306.cn/otn/resources/js/framework/station_name.js?station_version=1.9002"
self.headers={"User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/68.0.3440.7 Safari/537.36"}
def crawlTrainMess(self,from_station,to_station,train_date):
self.url="https://kyfw.12306.cn/otn/leftTicket/queryZ?leftTicketDTO.train_date={}&leftTicketDTO.from_station={}&leftTicketDTO.to_station={}&purpose_codes=ADULT".format(train_date,self.code[from_station],self.code[to_station])
response=requests.get(self.url,headers=self.headers)
train_json=json.loads(response.text)
results=train_json['data']['result']
train_list=[]
for i in results:
temp=i.split('|')
train_list.append([temp[3], temp[8], temp[9], temp[25], temp[26]])
#print(train_list)
return train_list
def crawlCodeMess(self):
response=requests.get(self.code_url,headers=self.headers)
station_list=response.text.split('@')[1 :]
code={}
for i in station_list:
temp=i.split('|')
code[temp[1]]=temp[2]
#print(code)
with open("code.json", 'w') as file:
file.write(str(code))
if __name__=="__main__":
ts=TrainService()
ts.crawlCodeMess()
需要先跑 TrainService.py 獲取到站點(diǎn)對(duì)應(yīng)的代碼信息code.json
然后在執(zhí)行 ui.py
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Python+threading模塊對(duì)單個(gè)接口進(jìn)行并發(fā)測(cè)試
這篇文章主要為大家詳細(xì)介紹了Python+threading模塊對(duì)單個(gè)接口進(jìn)行并發(fā)測(cè)試,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-06-06
關(guān)于Python turtle庫(kù)使用時(shí)坐標(biāo)的確定方法
這篇文章主要介紹了關(guān)于Python turtle庫(kù)使用時(shí)坐標(biāo)的確定方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-03-03
Python+wxPython實(shí)現(xiàn)一個(gè)簡(jiǎn)單的音樂播放器
這篇文章主要為大家詳細(xì)介紹了如何使用Python編程語(yǔ)言和wxPython模塊創(chuàng)建一個(gè)簡(jiǎn)單的音樂播放器,文中的示例代碼講解詳細(xì),感興趣的可以了解下2023-09-09
在VSCode中添加Python解釋器并安裝Python庫(kù)的方法
這篇文章主要介紹了在VSCode中添加Python解釋器并安裝Python庫(kù)的方法,本文分步驟通過圖文并茂的形式給大家介紹的非常詳細(xì),需要的朋友可以參考下2023-02-02
python實(shí)現(xiàn)簡(jiǎn)單顏色識(shí)別程序
這篇文章主要為大家詳細(xì)介紹了python實(shí)現(xiàn)簡(jiǎn)單顏色識(shí)別程序,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-02-02
Python創(chuàng)建普通菜單示例【基于win32ui模塊】
這篇文章主要介紹了Python創(chuàng)建普通菜單,結(jié)合實(shí)例形式分析了Python基于win32ui模塊創(chuàng)建普通菜單及添加菜單項(xiàng)的相關(guān)操作技巧,并附帶說明了win32ui模塊的安裝命令,需要的朋友可以參考下2018-05-05
從0編寫區(qū)塊鏈之用python解釋區(qū)塊鏈最基本原理
人工智能和區(qū)塊鏈誕生至今已經(jīng)有了十幾年,當(dāng)這些技術(shù)出現(xiàn)時(shí),人們都說他們會(huì)改變世界,但至今為止,這兩項(xiàng)技術(shù)對(duì)現(xiàn)實(shí)的影響依然有限,接下來通過本文介紹下從0編寫區(qū)塊鏈之用python解釋區(qū)塊鏈最基本原理,需要的朋友可以參考下2022-02-02
Python多線程中阻塞(join)與鎖(Lock)使用誤區(qū)解析
這篇文章主要為大家詳細(xì)介紹了Python多線程中阻塞join與鎖Lock的使用誤區(qū),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-04-04

