当前位置:   article > 正文

【Python抢票神器】12306火车票枪票软件到底靠谱吗?实测—终极攻略!_12306抢票小程序

12306抢票小程序

每年的节假日一到,大家头疼的总时同一个问题:你买到回家的票了吗?

尤其是大型的节日:”比如国庆、春节......“

数以亿计的人口迁移,让车票成了一年里最难买到的那张票。

跨站买票、买短途票上车补票、准点捡漏等已是老生常谈的技巧。随着互联网的发展,抢票软

件成为购票热门渠道。抢票软件的到底靠谱嘛?能抢到票嘛?

近日,小编给大家就正式编写一款Python实现12306查票以及自动购票抢票的小程序给大家,希望大家如愿!

文章源码免费获取 :

点击免费领取《CSDN大礼包》:

最新全套【Python入门到进阶资料 & 实战源码 & 安装工具】icon-default.png?t=N7T8https://mp.weixin.qq.com/s/wZXyzWCwB845LxAeiMWlmQ

正文

1、环境准备

1)运行环境:Python 3 、Pycharm、谷歌浏览器、谷歌驱动 。

2)模块准备: 

  1. requests ---> pip install requests (数据请求模块) prettytable ---> pip install prettytable (打印好看一些 )selenium ---> pip install selenium==3.141.0 (模拟人的行为去操作浏览器)json ---> 内置模块 不需要安装素材: city.json文件(直接找我拿)
  2. 复制代码

新手看过来

  1. 模块安装问题:
  2. - 如果安装python第三方模块:
  3. 1. win + R 输入 cmd 点击确定, 输入安装命令 pip install 模块名 (pip install requests) 回车
  4. 2. 在pycharm中点击Terminal(终端) 输入安装命令
  5. - 安装失败原因:
  6. - 失败一: pip 不是内部命令
  7. 解决方法: 设置环境变量
  8. - 失败二: 出现大量报红 (read time out)
  9. 解决方法: 因为是网络链接超时, 需要切换镜像源
  10. 清华:https://pypi.tuna.tsinghua.edu.cn/simple
  11. 阿里云:https://mirrors.aliyun.com/pypi/simple/
  12. 中国科技大学 https://pypi.mirrors.ustc.edu.cn/simple/
  13. 华中理工大学:https://pypi.hustunique.com/
  14. 山东理工大学:https://pypi.sdutlinux.org/
  15. 豆瓣:https://pypi.douban.com/simple/
  16. 例如:pip3 install -i https://pypi.doubanio.com/simple/ 模块名
  17. - 失败三: cmd里面显示已经安装过了, 或者安装成功了, 但是在pycharm里面还是无法导入
  18. 解决方法: 可能安装了多个python版本 (anaconda 或者 python 安装一个即可) 卸载一个就好
  19. 或者你pycharm里面python解释器没有设置好。
  20. ---------------------------------------------------------------------------------------------------
  21. 如何配置pycharm里面的python解释器?
  22. 1. 选择file(文件) >>> setting(设置) >>> Project(项目) >>> python interpreter(python解释器)
  23. 2. 点击齿轮, 选择add
  24. 3. 添加python安装路径
  25. ---------------------------------------------------------------------------------------------------
  26. pycharm如何安装插件?
  27. 1. 选择file(文件) >>> setting(设置) >>> Plugins(插件)
  28. 2. 点击 Marketplace 输入想要安装的插件名字 比如:翻译插件 输入 translation / 汉化插件 输入 Chinese
  29. 3. 选择相应的插件点击 install(安装) 即可
  30. 4. 安装成功之后 是会弹出 重启pycharm的选项 点击确定, 重启即可生效
  31. 复制代码

项目思路

  1. 12306 每天只能退票三次
  2. 查票
  3. 购票
  4. 建议谷歌或者火狐....
  5. 爬虫采集数据思路:
  6. 一. 分析数据来源
  7. 车票信息, 来源那个数据包 <车票信息请求那个网站url地址可以得到>
  8. 开发者工具 1 2
  9. 二. 代码实现步骤:
  10. 1. 发送请求, 对于刚刚分析得到url地址发送请求
  11. https://kyfw.12306.cn/otn/leftTicket/query?leftTicketDTO.train_date=2022-07-02&leftTicketDTO.from_station=CSQ&leftTicketDTO.to_station=SHH&purpose_codes=ADULT
  12. 2. 获取数据, 获取服务器返回响应数据, response
  13. 3. 解析数据, 提取我们想要车次信息
  14. 复制代码

代码展示

  1. import requests
  2. # 导入漂亮的表格输出模块 ---> 第三方模块 需要 在cmd里面进行 pip install prettytable
  3. import prettytable as pt
  4. # 导入json
  5. import json
  6. # 导入selenium模块 ---> 第三方模块 需要 在cmd里面进行 pip install selenium==3.141.0
  7. from selenium import webdriver
  8. # 导入账号密码
  9. from password import account, Password
  10. # 导入selenium控制键盘
  11. from selenium.webdriver.common.keys import Keys
  12. # 创建浏览器 <打开浏览器> 浏览器驱动放在python安装目录里面就不需要添加路径
  13. def get_ticket(num, from_station, to_station, date_key):
  14. driver = webdriver.Chrome()
  15. # 输入网址
  16. driver.get('https://kyfw.12306.cn/otn/resources/login.html')
  17. # 通过元素定位, 找到账号输入框 输入账号 send_keys() 发送或者输入内容
  18. driver.find_element_by_css_selector('#J-userName').send_keys(account) # 通过 css 选择器查找元素
  19. # 通过元素定位, 找到密码输入框 输入密码 send_keys() 发送或者输入内容
  20. driver.find_element_by_css_selector('#J-password').send_keys(Password) # 通过 css 选择器查找元素
  21. # 通过元素定位, 找到登陆按钮, 点击登陆
  22. driver.find_element_by_css_selector('#J-login').click()
  23. # 隐式等待
  24. driver.implicitly_wait(10)
  25. # 通过元素定位, 点击弹窗确定按钮 .表示class # 表示ID
  26. driver.find_element_by_css_selector('.modal-ft .btn').click()
  27. # 通过元素定位, 点击车票预定
  28. driver.find_element_by_css_selector('#link_for_ticket').click()
  29. # 通过元素定位, 点击键盘回车
  30. driver.find_element_by_css_selector('#fromStationText').send_keys(Keys.ENTER)
  31. # 通过元素定位, 清空输入框内容
  32. driver.find_element_by_css_selector('#fromStationText').clear()
  33. # 通过元素定位, 点击一下输入框
  34. driver.find_element_by_css_selector('#fromStationText').click()
  35. # 通过元素定位, 输入出发城市
  36. driver.find_element_by_css_selector('#fromStationText').send_keys(from_station)
  37. # 通过元素定位, 点击键盘回车
  38. driver.find_element_by_css_selector('#fromStationText').send_keys(Keys.ENTER)
  39. driver.find_element_by_css_selector('#toStationText').clear()
  40. driver.find_element_by_css_selector('#toStationText').click()
  41. driver.find_element_by_css_selector('#toStationText').send_keys(to_station)
  42. driver.find_element_by_css_selector('#toStationText').send_keys(Keys.ENTER)
  43. date = driver.find_element_by_css_selector('.inp-w #train_date')
  44. date.clear()
  45. date.send_keys(date_key)
  46. # 通过元素定位, 点击查询按钮
  47. driver.find_element_by_css_selector('#query_ticket').click()
  48. if num == 1:
  49. driver.find_element_by_css_selector(f'#queryLeftTable tr:nth-child({num}) a.btn72').click()
  50. elif num != 1:
  51. driver.find_element_by_css_selector(f'#queryLeftTable tr:nth-child({num + 1}) a.btn72').click()
  52. # #normalPassenger_0
  53. driver.find_element_by_css_selector('#normalPassenger_1').click()
  54. driver.find_element_by_css_selector('#submitOrder_id').click()
  55. driver.find_element_by_css_selector('#qr_submit_id').click()
  56. driver.find_element_by_css_selector('#qr_submit_id').click()
  57. f = open('city.json', encoding='utf-8')
  58. text = f.read() # 读取文件
  59. json_data = json.loads(text)
  60. from_city = input('请输入你要出发城市: ')
  61. to_city = input('请输入你要到达城市: ')
  62. date = input('请输入你要出发的时间: ')
  63. from_station = json_data[from_city]
  64. to_station = json_data[to_city]
  65. """
  66. 发送请求, 模拟浏览器对于url地址发送请求
  67. 快捷批量替换方法:
  68. 选中内容, ctrl + R 输入正则表达式命令点击全部替换即可
  69. (.*?): (.*)
  70. '$1': '$2',
  71. """
  72. # 确定请求网址 ---> 如果对于长链接, 我们是可以分段写 ? 后面都是属于请求参数
  73. url = 'https://kyfw.12306.cn/otn/leftTicket/query'
  74. # 请求参数 ---> 字典数据类型, 构建成完整键值对, 键值对与键值对之间要用逗号隔开
  75. data = {
  76. 'leftTicketDTO.train_date': date,
  77. 'leftTicketDTO.from_station': from_station,
  78. 'leftTicketDTO.to_station': to_station,
  79. 'purpose_codes': 'ADULT',
  80. }
  81. # 请求头 ---> 伪装模拟浏览器的, 把python代码伪装成浏览器发送请求
  82. headers = {
  83. # User-Agent: 用户代理, 表示浏览器基本身份标识
  84. 'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/101.0.0.0 Safari/537.36',
  85. }
  86. # 发送请求 ---> 返回数据 <Response [200]> 响应对象 200状态码表示请求成功
  87. response = requests.get(url=url, params=data, headers=headers)
  88. # 获取数据 response.json() 获取响应对象json字典数据
  89. # 解析数据 ---> 根据数据类型以及你想要获取数据内容, 选择最合适提取方式 根据冒号左边的内容, 提取冒号右边内容
  90. result = response.json()['data']['result']
  91. # 实例化对象
  92. tb = pt.PrettyTable()
  93. tb.field_names = [
  94. '序号',
  95. '车次',
  96. '出发时间',
  97. '到达时间',
  98. '耗时',
  99. '特等座',
  100. '一等',
  101. '二等',
  102. '软卧',
  103. '硬卧',
  104. '硬座',
  105. '无座',
  106. ]
  107. page = 0
  108. lis = []
  109. # for循环 就把列表里面元素一个一个提取出来
  110. for index in result:
  111. # split() 字符串分割方法 --> 返回是列表
  112. content_list = index.split('|')
  113. # 根据列表索引位置提取内容
  114. num = content_list[3] # 车次
  115. start_time = content_list[8] # 出发时间
  116. end_time = content_list[9] # 到达时间
  117. use_time = content_list[10] # 耗时
  118. topGrade = content_list[25] # 特等座
  119. if topGrade:
  120. pass
  121. else:
  122. topGrade = content_list[32]
  123. first_class = content_list[31] # 一等
  124. second_class = content_list[30] # 二等
  125. hard_sleeper = content_list[28] # 硬卧
  126. hard_seat = content_list[29] # 硬座
  127. no_seat = content_list[26] # 无座
  128. soft_sleeper = content_list[23] # 软卧
  129. dit = {
  130. '车次': num,
  131. '出发时间': start_time,
  132. '到达时间': end_time,
  133. '耗时': use_time,
  134. '特等座': topGrade,
  135. '一等': first_class,
  136. '二等': second_class,
  137. '软卧': soft_sleeper,
  138. '硬卧': hard_sleeper,
  139. '硬座': hard_seat,
  140. '无座': no_seat,
  141. }
  142. lis.append(dit)
  143. tb.add_row([
  144. page,
  145. num,
  146. start_time,
  147. end_time,
  148. use_time,
  149. topGrade,
  150. first_class,
  151. second_class,
  152. soft_sleeper,
  153. hard_sleeper,
  154. hard_seat,
  155. no_seat,
  156. ])
  157. page += 1
  158. # 更加方便直观查看 索引位置 ---> 列表可以通过索引位置取值
  159. # num = 0
  160. # for i in content_list:
  161. # # i 列表里面元素, num 对应列表索引位置
  162. # print(i, num)
  163. # num += 1
  164. # break
  165. print(tb)
  166. num = input('请输入你想要购买车票序号: ')
  167. get_ticket(num=int(num), from_station=from_city, to_station=to_city, date_key=date)
  168. 复制代码

总结

好啦!这款Python实现12306查票以及自动购票的小程序写到这里就正式over了!大家还想看爬什么的可以跟我讲,欢迎留言!

最后给大家分享一份全套的 Python 学习资料,给那些想学习 Python 的小伙伴们一点帮助!

 点击免费领取《CSDN大礼包》:

最新全套【Python入门到进阶资料 & 实战源码 & 安装工具】

一、Python所有方向的学习路线

Python所有方向路线就是把Python常用的技术点做整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。

二、Python课程视频

我们在看视频学习的时候,不能光动眼动脑不动手,比较科学的学习方法是在理解之后运用它们,这时候练手项目就很适合了。

img

三、全套PDF电子书

书籍的好处就在于权威和体系健全,刚开始学习的时候你可以只看视频或者听某个人讲课,但等你学完之后,你觉得你掌握了,这时候建议还是得去看一下书籍,看权威技术书籍也是每个程序员必经之路。

四、清华编程大佬出品《漫画看学Python》

用通俗易懂的漫画,来教你学习Python,让你更容易记住,并且不会枯燥乏味。

img

五、Python实战案例

光学理论是没用的,要学会跟着一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。

img

六、互联网企业面试真题

我们学习Python必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有阿里大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。

img

点击免费领取《CSDN大礼包》:

最新全套【Python入门到进阶资料 & 实战源码 & 安装工具】

本文内容由网友自发贡献,转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号