查看原文
其他

火了!开源的Python抢票神器,支持候补抢票(文末送书)

刘早起 IT服务圈儿 2022-09-10

作者 l 刘早起

来源 l 本文转载自公众号:早起Python(ID:zaoqi-python)


留 言 包 邮 送 书


春运即将到来,抢票回家又该提上日程了!在Github上也有很多优秀的开发者开源了一些基于Python的抢票项目,比如一直很火的12306/py12306,目前已经累计超40k Star!



但如果你尝试使用,会发现由于12306的验证码机制升级,这两个项目的登陆模块都挂掉了,大概去年十月就已经不能使用。

but不慌,经过一番探索,我找到了一个还能完美使用的抢票项目,并联系到开发者@罐子里的茶呢,了解到只要对登陆模块的一些接口地址进行变更,以及对部分参数的获取逻辑进行调整,就能重新盘活Python抢票项目12306,地址如下

https://github.com/gzldc/12306


本文就将基于该项目详细的指导大家如何快速使用Python抢票,顺利回家!开始之前我们需要了解一下整体抢票思路


下载与依赖安装

运行本项目之前需要将你的Python升级到Python3.6或者更高版本,我是Python3.8没有问题。首先用git将原项目代码拉下来

git clone https://github.com/gzldc/12306.git


或者直接下载压缩包并解压


解压完的目录应该如下


之后启动终端/命令行(Mac/Win),并cd进入项目目录,执行如下代码安装相关依赖

pip install -r requirements.txt


需要注意的是,如果下载速度过慢可以切换源来解决,亲测使用阿里云镜像是速度最快的

https://mirrors.aliyun.com/pypi/simple


关于安装各种库本文不是本文介绍的重点,总之requirements.txt依赖库必须正确被安装,如果出现任何安装上的问题,请自行百度。

获取登陆信息

之前我们说到,GitHub排名第一第二的12306抢票项目挂掉的原因都是在登陆验证码没法处理上,但我们现在使用的项目并不是使用用户名与密码管理账户,只需要在登陆时提取自己账户的相关cookie字段即可,可以按照以下步骤进行。


首先打开12306官网,进入登陆页面并按下F12,并选择Network


之后输入账号密码验证码点击登陆,之后点击XHR


如上图指示,找到uamauthclient数据包进入并点击Cookies,之后按照下图的指示记录下tkRAIL_EXPIRATIONRAIL_DEVICEID三个字段的value,复制下来保存好,待会要用到


到这里就成功拿到了12306校验我们身份的关键信息,让我们继续。

配置抢票信息

现在回到项目目录,打开目录下的TickerConfig.py进行配置,里面有很多字段大家可以自行查看说明与配置,本文仅介绍部分关键字段。


首先你需要修改53-55行的三个变量值,替换为我们刚刚保存的tkRAIL_EXPIRATIONRAIL_DEVICEID三个字段的value,这一步非常重要,因为使用本项目无需输入账号密码,就靠这三个参数下单


之后如下图修改乘车人、车次、出行日期等相关信息,这部分自行填写,不多解释了


到这里我们就可以直接使用了,当然你还可以继续按照这个模版文件说明对CDN加速、代理ip、抢票模式等设置进行调整,最后保存退出即可。

启动项目

最后让我们启动项目开始抢票,回到终端/命令行。执行如下代码开启CDN加速

python3 run.py c


之后挂在后台,重新打开一个终端/命令行并进入项目目录,执行下面代码开始抢票

python3 run.py r


如上图所示,不出意外的话就会输出一大堆日志,我选择的是杭州去芜湖的票,因为有余票,所以就没有进入抢票模式,直接就下单待支付了


回到12306,点开我的订单发现有一张票躺在那里待支付,说明一切从登陆到下单所有功能都是可以正常使用的!

一些说明

因为时间关系,我没有在抢票模式模式下进一步测试,在和项目作者以及部分群友交流后,再说明几点方便大家使用

  • 如果在Windows下安装tensorflow失败,可以适当降低版本或者升高版本都是可以的(1.14.0rc\1.14.0rc\1.15.0\1.15.0rc均可)
  • 启动项目时的CDN加速不是必须的,你可以选择不启动即直接执行python3 run.py r
  • tk等登陆cookies信息可能有一定时效性,所以可能需要定时检查一下
  • 如果是候补车票,需要通过人证一致性核验的用户及激活的“铁路畅行”会员可以提交候补需求,需要按照操作说明在铁路12306app上完成人证核验。
  • 软件为全自动候补加捡漏,如果软件候补成功则会停止抢票,发出邮件通知,但是不会影响你继续捡漏,如果这个时候捡漏捡到的话,也是可以付款成功的,也就是说,捡漏+候补模式可以最大程度提升抢票成功率

最后,如果GitHub下载源码速度慢,你可以在公众号「IT服务圈儿」后台回复12306获取百度云下载链接


👇👇👇留言的朋友均有机会获得书籍呦~


今日书单 | 包邮送推荐理由:本书结合Python在数据分析领域的特点,介绍如何在数据平台上集成使用Python。不仅阐述了Python在大数据平台上的应用技巧,而且关于大数据平台管理和操作的介绍说明贯穿全书,因此对于希望学习大数据知识的读者,本书同样非常适合。

推荐理由:本书通过大量的实战案例,让读者能够跟随教程一步步独立搭建起一套完整的大数据处理系统,并具备一定的运维开发能力,不仅适合初学者入门,也适合具备一定开发经验的从业者进阶提高。

推荐理由:本书介绍了如何使用Python来编写网络爬虫程序,内容包括网络爬虫简介、发送请求、提取数据、使用多个线程和进程进行并发抓取、抓取动态页面中的内容、与表单进行交互、处理页面中的验证码问题及使用Scrapy和分布式进行数据抓取,并在最后介绍了使用本书讲解的数据抓取技术对几个真实的网站进行抓取的实例,旨在帮助读者活学活用书中介绍的技术。

推荐理由:从介绍分布式一致性算法开始,分析了Raft算法以及Raft算法所依赖的理论,在此基础上讲解并实现了Raft算法以及基于Raft算法的KV服务。通过本书,可以深入了解Raft算法的运行机制,也可以学到如何相对正确地实现Raft。


活动规则:


我们将从精选留言中随机抽取 8名 伙伴赠书,中奖者可在上方书单中任选一本图书,我们包邮赠送。书籍有限,中奖后先选先得。


  • 《python大数据分析从入门到精通》 *2

  • 《海量数据处理与大数据技术实战》 *2

  • 《python 3.x网了爬虫从零基础到项目实战》 *2

  • 《分布式一致性算法开发实战》 *2


小锦鲤玩法:

  • 本次小锦鲤我们将从精选留言中随机抽取2~5名 小锦鲤,赠送红包 6.6 ~


开奖后圈儿会给中奖者发送留言,请大家凭留言截图添加圈儿微信号:jb_quaner领取


留言要求:

  • 内容与本文核心信息相关

  • 留想要的书籍名称

  • 每人仅限精选一条留言(用心留言更容易上墙)

  • 为了大家都有机会中奖,每个小伙伴每个星期只能中一次奖哦~


截止时间: 2021 年 1 月 14 日 16:00 整


每天 17:30 不见不散!



有偿征稿IT服务圈儿正式开启投稿通道,稿费:60~5000元不等,长期有效!!!
点此查看详情


1、人脸识别“抓”错了人,他在监狱呆了10天

2、如何打造一个经常宕机的业务系统?

3、虾米音乐宣布关停!一代人的音乐回忆落幕

4、华为P50外形首度曝光!

识别关注我们

了解更多精彩内容

点分享

点点赞

点在看

您可能也对以下帖子感兴趣

文章有问题?点此查看未经处理的缓存