【人工智能写代码】一键查询12306剩余车票的Python脚本解析

本文主要是介绍【人工智能写代码】一键查询12306剩余车票的Python脚本解析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一键查询12306剩余车票的Python脚本解析

在节假日或旅游高峰期,购买火车票往往是一件令人头疼的事情。为了简化这一过程,本文将介绍一个使用Python编写的脚本,它可以帮助你快速查询12306网站上的剩余车票信息,并以表格的形式展示出来。下面,我们将逐步解析这个脚本的工作原理。

在这里插入图片描述
在这里插入图片描述

环境准备

在开始之前,确保你的环境中已经安装了以下Python库:

  • os:用于处理操作系统相关的功能。
  • pandas:用于数据处理和分析。
  • requests:用于发送HTTP请求。
  • prettytable:用于打印格式化的表格。

你可以使用pip命令来安装这些库:

pip install os pandas requests prettytable

脚本功能

该脚本的主要功能是:

  1. 自动获取城市名称对应的城市代码。
  2. 从12306网站查询指定日期的火车票信息。
  3. 将查询结果以表格形式展示。
  4. 将查询结果保存到Excel文件中。

代码解析

全局变量初始化

favorite_names = ''
start = ""
end = ""

这里定义了三个全局变量,分别用于存储用户偏好的城市名、起始站和目的站。

城市代码获取

def init():# ...省略部分代码...return [start, end, time]

init函数用于初始化脚本,包括从12306网站获取城市名称对应的城市代码,并询问用户输入出发地、目的地和出发日期。

城市代码转换

def get_city_code(city):# ...省略部分代码...return None

get_city_code函数通过解析init函数获取的城市名称列表,返回对应的城市代码。

主函数入口

if __name__ == '__main__':# 初始化start, end, time = init()# ...省略部分代码...

脚本的入口点在__main__块中,这里调用了init函数来获取必要的信息,并开始查询流程。

查询车票信息

res = requests.get(url, headers=head).json()

通过requests库发送HTTP请求到12306的查询接口,并解析返回的JSON数据。

结果展示与保存

tb = pt.PrettyTable(['车次', '出发时间', '到达时间', '商务座', '一等座', '二等座', '一等座(软卧)', '二等座(软卧)', '硬座'])
# ...省略部分代码...
print(tb)
df.to_excel('12306购票汇总.xlsx')

使用prettytable库打印出一张包含车次、出发时间、到达时间等信息的表格,并将这些信息保存到Excel文件中。

总结

通过上述Python脚本,我们可以快速地查询12306网站上的剩余车票信息,并以表格的形式直观展示。这个脚本不仅提高了查询效率,还方便了用户对信息的整理和保存。在使用此脚本时,请确保遵守12306网站的使用协议,并注意个人隐私和账户安全。

请注意,12306网站的结构可能会发生变化,因此脚本可能需要根据实际情况进行相应的调整。此外,由于12306网站的反爬虫策略,频繁的查询请求可能会导致IP被封禁,因此请合理使用此脚本。

完整代码

这篇关于【人工智能写代码】一键查询12306剩余车票的Python脚本解析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/833839

相关文章

redis中使用lua脚本的原理与基本使用详解

《redis中使用lua脚本的原理与基本使用详解》在Redis中使用Lua脚本可以实现原子性操作、减少网络开销以及提高执行效率,下面小编就来和大家详细介绍一下在redis中使用lua脚本的原理... 目录Redis 执行 Lua 脚本的原理基本使用方法使用EVAL命令执行 Lua 脚本使用EVALSHA命令

Python中pywin32 常用窗口操作的实现

《Python中pywin32常用窗口操作的实现》本文主要介绍了Python中pywin32常用窗口操作的实现,pywin32主要的作用是供Python开发者快速调用WindowsAPI的一个... 目录获取窗口句柄获取最前端窗口句柄获取指定坐标处的窗口根据窗口的完整标题匹配获取句柄根据窗口的类别匹配获取句

利用Python打造一个Excel记账模板

《利用Python打造一个Excel记账模板》这篇文章主要为大家详细介绍了如何使用Python打造一个超实用的Excel记账模板,可以帮助大家高效管理财务,迈向财富自由之路,感兴趣的小伙伴快跟随小编一... 目录设置预算百分比超支标红预警记账模板功能介绍基础记账预算管理可视化分析摸鱼时间理财法碎片时间利用财

MyBatis模糊查询报错:ParserException: not supported.pos 问题解决

《MyBatis模糊查询报错:ParserException:notsupported.pos问题解决》本文主要介绍了MyBatis模糊查询报错:ParserException:notsuppo... 目录问题描述问题根源错误SQL解析逻辑深层原因分析三种解决方案方案一:使用CONCAT函数(推荐)方案二:

Python中的Walrus运算符分析示例详解

《Python中的Walrus运算符分析示例详解》Python中的Walrus运算符(:=)是Python3.8引入的一个新特性,允许在表达式中同时赋值和返回值,它的核心作用是减少重复计算,提升代码简... 目录1. 在循环中避免重复计算2. 在条件判断中同时赋值变量3. 在列表推导式或字典推导式中简化逻辑

python处理带有时区的日期和时间数据

《python处理带有时区的日期和时间数据》这篇文章主要为大家详细介绍了如何在Python中使用pytz库处理时区信息,包括获取当前UTC时间,转换为特定时区等,有需要的小伙伴可以参考一下... 目录时区基本信息python datetime使用timezonepandas处理时区数据知识延展时区基本信息

Python位移操作和位运算的实现示例

《Python位移操作和位运算的实现示例》本文主要介绍了Python位移操作和位运算的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 位移操作1.1 左移操作 (<<)1.2 右移操作 (>>)注意事项:2. 位运算2.1

Qt实现网络数据解析的方法总结

《Qt实现网络数据解析的方法总结》在Qt中解析网络数据通常涉及接收原始字节流,并将其转换为有意义的应用层数据,这篇文章为大家介绍了详细步骤和示例,感兴趣的小伙伴可以了解下... 目录1. 网络数据接收2. 缓冲区管理(处理粘包/拆包)3. 常见数据格式解析3.1 jsON解析3.2 XML解析3.3 自定义

使用Python和Pyecharts创建交互式地图

《使用Python和Pyecharts创建交互式地图》在数据可视化领域,创建交互式地图是一种强大的方式,可以使受众能够以引人入胜且信息丰富的方式探索地理数据,下面我们看看如何使用Python和Pyec... 目录简介Pyecharts 简介创建上海地图代码说明运行结果总结简介在数据可视化领域,创建交互式地

利用python实现对excel文件进行加密

《利用python实现对excel文件进行加密》由于文件内容的私密性,需要对Excel文件进行加密,保护文件以免给第三方看到,本文将以Python语言为例,和大家讲讲如何对Excel文件进行加密,感兴... 目录前言方法一:使用pywin32库(仅限Windows)方法二:使用msoffcrypto-too