python实现火车票查询工具_Python 实现一个火车票查询的工具

本文介绍了使用Python实现火车票查询工具的方法。该工具可根据输入的出发站、到达站和时间,返回车次及余票信息,还支持附加选项查询特定类型火车。实现过程包括对12306网站抓包分析、用正则表达式处理车站简称、用docopt处理命令行输入、编写主程序及用prettytable模块输出结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

原标题:Python 实现一个火车票查询的工具

作者 sexycoder

本文转载自简书,转载需授权

使用 python 实现一个查询火车票的小工具

主要功能:

输入出发车站,到达车站,时间,然后返回所有的车次信息,和余票信息

支持输入附加选项查询不同的火车的类型,比如高铁,动车。#查询上海到北京

2017-04-25的高铁和动车的车票,-g -d 是附加选项 表示高铁和动车python3 trains.py -gd 上海 北京

2017-04-25

运行结果:

1. 对12306网站买票过程抓包分析

点击查询之后,通过抓包发现返回了一个json的文件,查看这个文件,就是保存着具体车次的信息。抓包如下图所示。

请求的url 是:

GET /otn/leftTicket/query?leftTicketDTO.train_date=2017-04-20&leftTicketDTO.from_station=TJP&leftTicketDTO.to_station=TYV&purpose_codes=ADULT HTTP/1.1

发现这个请求使用的是get方法,然后传递了四个参数,一个是出发站,一个是到达车站,一个是成年人or学生,最后一个是时间。如下图:

但是有一个问题是,我输入的是天津到太原,但是这个却转换成了拼音的简称。必须要找到这个转换的字典是什么,这样才能正确的使用这个接口。

在网页的源代码找到这个文件,station_name.js 文件,如下图:

js文件的格式是,如下图,使用的话,必须要想用正则表达式处理一下:

2. 使用正则表达式处理这个js文件

使用正则表达式,将js 文件里面的车站名字和对应的简称提取出来,然后写入到一个station.py 文件里面,作为字典,程序运行的时候,将这个文件以模块的形式包含进去。

关于正则表达式,先占一个坑,以后在详细的写。

正则表达式的代码:

运行的时候:

# 将输出重定向到一个新的文件stations.py里面python3test3.py> stations.py

3. 使用docopt 优雅的完成命令行的输入

docopt 是一个很优雅的处理输入的一个模块,docopt可以根据你写的文档描述,可以自动为你生成解析器,可以非常容易的为你的python程序创建命令行界面。

4. 主程序

4.1 处理url

4.2 输出

运行结果:

5. 使用prettytable模块 优雅的输出

详细:

推荐阅读

责任编辑:

Python可以用来开发火车票查询工具,通常利用第三方API或网站数据抓取技术。例如,通过requests库访问中国铁路客户服务中心的API,或者使用BeautifulSoup等库爬取12306官网的数据。下面是一个简单的步骤概述: 1. **安装必要的库**:首先需要安装如requests、lxml(用于解析HTML)、pandas等用于数据处理的库。 2. **获取API或网页数据**:如果是官方API,需要申请相应的API key,并按照文档调用接口,获取列车信息。如果没有官方API,就直接抓取网页源码。 3. **数据结构和解析**:获取到的数据通常是JSON或HTML格式,需要用适当的方式解析,提取出关键信息如车次、发站、到站、时间等。 4. **用户界面**:创建命令行交互界面或者GUI,允许用户输入出发地、目的地和日期,然后显示查询结果。 5. **异常处理**:考虑到网络请求可能存在失败的情况,需要对可能出现的错误进行妥善处理。 ```python # 示例代码片段 import requests from bs4 import BeautifulSoup def query_train_tickets(start_city, end_city, date): url = "https://kyfw.12306.cn/otn/leftTicket/init" # 使用实际的API接口地址和参数替换这里 params = {'leftTicketDTO.train_date': date, 'leftTicketDTO.from_station': start_city, 'leftTicketDTO.to_station': end_city} try: response = requests.get(url, params=params) if response.status_code == 200: soup = BeautifulSoup(response.text, 'lxml') # 解析并返回火车票信息 return process_ticket_data(soup) else: print("查询失败,状态码:", response.status_code) except Exception as e: print("查询过程中发生错误:", str(e)) def process_ticket_data(html_content): # 这里是对解析后的HTML内容进行进一步处理 pass start_city = input("请输入出发城市:") end_city = input("请输入到达城市:") date = input("请输入查询日期:") tickets = query_train_tickets(start_city, end_city, date) if tickets: for ticket in tickets: print(ticket) ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值