亲测,手把手教你用Python抢票

随着春节的临近,大家都在和12306斗智斗勇。今天,大数据文摘推出不到100行的Python程序帮助大家来抢票。

首先说明一下,我们程序的出发点是能用机器做的事就用机器做,需要人来做的事还是要自己来做。因此,12306上五花八门的验证码还是需要大家自己动手输入确认的。另外,本程序对容错什么的考虑较少,请大家见谅。

我们要用到浏览器chrome,还没有安装的读者可以从这个下载地址下载chrome并进行安装:http://chromedriver.storage.googleapis.com/index.html?path=2.20/,大家可以根据自己的电脑系统选择下载包进行安装。如果你用的是MAC,可以直接通过brew install chromedriver来安装。

现在一切就绪,让我们学习一下这个Python程序。

Splinter是一个自动化测试网络应用的Python库。有了Splinter,就可以将打开浏览器、输入URL、填写表单、点击按钮等全部操作自动化。因此,我们需要引入这个库。通过pip install splinter来安装。

1 from splinter.browser import Browser

2 from time import sleep

#traceback模块被用来跟踪异常返回信息

3 import traceback

# 设定用户名,密码

4 username = u"用户名"

5 passwd = u"密码"

# 起始地址的cookies值要自己去找, 下面两个分别是上海, 营口东。如何找,我们在文#后有简单的介绍

6 starts = u"%u4E0A%u6D77%2CSHH"

7 ends = u"%u8425%u53E3%u4E1C%2CYGT"

# 时间格式2016-02-01

8 dtime = u"2016-02-01"

# 车次,选择第几趟,0则从上之下依次点击

9 order = 0

#设定乘客姓名

10 pa = u"乘客姓名"

#设定网址

11 ticket_url = "https://kyfw.12306.cn/otn/leftTicket/init"

12 login_url = "https://kyfw.12306.cn/otn/login/init"

13 initmy_url = https://kyfw.12306.cn/otn/index/initMy12306

#登录网站

14 def login():

15 b.find_by_text(u"登录").click()

16 sleep(3)

我们在这里尝试了模拟登录12306,得到结果如下:

登录页面成功显示!

#第17至20行代码用于自动登录,username是12306账号名,passwd是12306密码

17 b.fill("loginUserDTO.user_name", username)

18 sleep(1)

19 b.fill("userDTO.password", passwd)

20 sleep(1)

在我们的模拟登录中,结果如下:

成功登录!

接下来的验证码还是要大家自己动手输入啦!据说12306的验证码辨识难度堪比常识竞赛。在此,大数据文摘祝你好运!

21 print u"等待验证码,自行输入..."

22 while True:

23 if b.url != initmy_url:

24 sleep(1)

25 else:

26 break

#购票

27 def huoche():

28 global b

#使用splinter打开chrome浏览器

29 b = Browser(driver_name="chrome")

#返回购票页面

30 b.visit(ticket_url)

现在让我们来看看程序运行结果

看到了吗?网页能正常打开!

31 while b.is_text_present(u"登录"):

32 sleep(1)

33 login()

34 if b.url == initmy_url:

35 break

36 try:

37 print u"购票页面..."

38 # 跳回购票页面

39 b.visit(ticket_url)

40 # 加载查询信息

我们的模拟登录中以上海为始发站,营口东为终点站,时间选定2016年2月1日

41 b.cookies.add({"_jc_save_fromStation": starts})

42 b.cookies.add({"_jc_save_toStation": ends})

43 b.cookies.add({"_jc_save_fromDate": dtime})

44 b.reload()

让我们一起来看看运行结果如何?

45 sleep(2)

46 count = 0

47 # 循环点击预订

48 if order != 0:

49 while b.url == ticket_url:

50 b.find_by_text(u"查询").click()

程序自动点击查询后,结果如下:

51 count +=1

52 print u"循环点击查询... 第 %s 次" % count

53 sleep(1)

54 try:

55 b.find_by_text(u"预订")[order - 1].click()

程序自动点击预订后,结果如下:

哇啦!我们成功预订了春运车票!

56 except:

57 print u"还没开始预订"

58 continue

59 else:

60 while b.url == ticket_url:

61 b.find_by_text(u"查询").click()

62 count += 1

63 print u"循环点击查询... 第 %s 次" % count

64 sleep(1)

65 try:

66 for i in b.find_by_text(u"预订"):

67 i.click()

68 except:

69 print u"还没开始预订"

70 continue

71 sleep(1)

注意:可以通过修改sleep的参数来调整延时, 但延时不要太低, 防止被12306网站认为是刷票屏蔽掉.

72 b.find_by_text(pa)[1].click()

如果你运气不好,程序会给出一个这样的信息:

73 print u"能做的都做了.....不再对浏览器进行任何操作"

如果出现这样的信息,你也不要灰心,重新执行程序,让好运降临!

74 except Exception as e:

75 print(traceback.print_exc())

76 if __name__ == "__main__":

77 huoche()

小技巧:

如何在chrome中获得起始站和终点站等的cookie值?

大家可以先登录一下12306,输入地点日期什么的查询一下,然后在chrome浏览器中按F12,出现如下页面,在resource选项里找到相应的值。

大家可以看到对应表格中的cookie值:

_jc_save_fromeStation的值为出发地

_jc_save_toSatation的值为目的地

_jc_save_fromDate 出发日期

_jc_save_toDate返程日期

看到这里,你还不快点动手抢票?

原文发布时间为:2015-12-10

时间: 2024-11-03 20:02:17

亲测,手把手教你用Python抢票的相关文章

手把手教你用Python抓取AWS的日志(CloudTrail)数据

数据时代,利用数据做决策是大数据的核心价值.   本文手把手,教你使用python进行AWS的CloudTrail配置,进行日志抓取.进行数据分析,发现数据价值!   如今是云的时代,许多公司都把自己的IT架构部署在基础架构云(IaaS)上.著名的IaaS提供商有亚马逊,微软(Azure),IBM等,国内也有诸如阿里云等.其中,亚马逊毫无疑问是该市场的领军者.   AWS提供了非常多的服务,领先了竞争对手一大截.并且AWS提供非常丰富的API,其API基于Rest,所以很容易被不同的语言的平台来

手把手教你用Python抓取热门景点热力图!(附代码)

国庆倒计时1天,我们即将迎来8天的小长假,相信很多小伙伴们已经提前规划国庆去哪儿?你是选择去人最少的单位加班呢?还是选择人山人海的景点观光? 如果去人最少的单位加班,一定要记得告知老板,以望升职加薪走上人生巅峰: 如果选择人山人海的景点,一定要提前查看攻略,比如下文中使用 Python 技术抓取热门景点的热力图. 金秋九月,丹桂飘香,在这秋高气爽,阳光灿烂的收获季节里,我们送走了一个个暑假余额耗尽哭着走向校园的孩子们,又即将迎来一年一度伟大祖国母亲的生日趴体(无心上班,迫不及待想为祖国母亲庆生)

独家 | 手把手教你用Python 3创建用于机器学习开发的Linux虚拟机(附安装教程&代码)

Linux是使用Python进行机器学习开发的极佳环境.这些工具能够被简便快捷地安装,并且您可以直接开发和运行大型模型. 在本教程中,您将了解如何使用Python创建和安装用于机器学习的Linux虚拟机.完成本教程后,您将知道: 如何下载和安装VirtualBox来管理虚拟机如何下载和安装Fedora Linux如何在Python 3中为机器学习安装一个SciPy环境 如果您的电脑操作系统是Windows.Mac OS X和Linux.那么本教程是适合您的. Linux虚拟机的好处 您可能有很多

手把手教你用 Python 和 Scikit-Learn 实现垃圾邮件过滤

文本挖掘(Text Mining,从文字中获取信息)是一个比较宽泛的概念,这一技术在如今每天都有海量文本数据生成的时代越来越受到关注.目前,在机器学习模型的帮助下,包括情绪分析,文件分类,话题分类,文本总结,机器翻译等在内的诸多文本挖掘应用都已经实现了自动化. 在这些应用中,垃圾邮件过滤算是初学者实践文件分类的一个很不错的开始,例如 Gmail 账户里的"垃圾邮箱"就是一个垃圾邮件过滤的现实应用.下面我们将基于一份公开的邮件数据集 Ling-spam,编写一个垃圾邮件的过滤器.Ling

大神手把手教你:(Python)序列数据的One Hot编码

更多深度文章,请关注:https://yq.aliyun.com/cloud 机器学习算法无法直接用于数据分类.数据分类必须转换为数字才能进一步进行. 在本教程中,你将发现如何将输入或输出的序列数据转换为一种热编码,以便于你在Python中深度学习的序列分类问题中使用. 看完本教程后,你将会了解: ·   1.什么是整数编码和One-Hot编码,以及为什么它们在机器学习中是必需的. ·   2.如何在Python中手工计算一个整数编码和One-Hot编码. ·   3.如何使用scikit-le

手把手教你用 Python 实现针对时间序列预测的特征选择

要将机器学习算法应用于时间序列数据,需要特征工程的帮助. 例如,单变量的时间序列数据集由一系列观察结果组成,它们必须被转换成输入和输出特征,才能用于监督性学习算法. 但这里有一个问题:针对每个时间序列问题,你可以处理的特征类型和数量,却并没有明确的限制.当然,古典的时间序列分析工具(如相关图correlogram)可以帮助评估滞后变量(lag variables),但并不能直接帮助开发者对其他类型的特征进行选择,例如从时间戳(年.月.日)和移动统计信息(如移动平均线moving average)

人生日历抢票:比预售时间提早2分钟

今日是购买国庆返程票的高峰时期的最后一天,各路抢票软件层出不穷.小编实测,人生日历抢票插件,比火车票官网的预售时间点早两分钟,这两分钟可以大大提高抢票成功的几率.下面跟随小编一起用人生日历抢火车票吧! 打开人生日历界面下方的火车票按钮,点击进入该插件.登录12306的账户,系统会自动输入验证码,登录进去之后,选择好出发站和到达站.日期,并且在出票时间查询入口查询好该出发站的预售时间点,如小编选择长沙到深圳的火车,查到长沙的起售时间是15点.抢票心得:一定要在火车票预售时间前1个小时或半个小时登录

手把手教你从零搭建Python数据分析环境

由于最近再做推荐系统的特征处理,需要借助一些工具来筛选特征.最初使用了R,R的安装很简单,而且API也很容易使用,直接就能出图.后来,发现很多人在python和R之间做选择,所以我也在两个工具间摇摆不定.后来,发现Tensorflow里面有很多python的代码,而且python可以做爬虫写web,几乎是万金油的角色.本着想找一门以后日常使用的工具的心态,最终还是选择了python. 那么本篇就从下面几个方面介绍下,如何在日常使用python做数据分析: python安装以及numpy.matp

网上订票抢票攻略(亲测)

 1.首先我推荐的浏览器是360极速抢票浏览器,注意:一定要从官网下载http://www.360.cn/.因为好多其他来源的都加入了一些木马插件. 2.右上角有个醒目的红色票的按钮,点一下,然后利用浏览器自动安装证书 3.进入选定要的车次等信息 4.如果发票时间是8:00.那么在7:58左右就要开始点击刷票,非常方便. 5.祝您买票成功