手把手教你用python一键抢12306火车票(附代码)

哈喽,哈喽~,一年一度的抢火车票大战正式拉开序幕…

然饿大多数人碰到的是这种情况:当你满心期待摩拳擦掌准备抢票的时候,你会发现一票难求!想回趟家真难!

那么作为程序猿的你,当然要用程序猿的方式来抢票!下面分享用python来抢票!

欢迎关注公众号:每日治愈系列,提供各种免费资源!也可以咨询代码问题哦!

在这里插入图片描述

 

城市cookie可根据具体需求自行添加!不懂的点这里!

  1. 导入所需模块:
import re
from splinter.browser import Browser
from time import sleep
import sys
import httplib2
from urllib import parse
import smtplib
from email.mime.text import MIMEText
import time

此部分导入了代码所需的各种模块,用于实现不同的功能,包括正则表达式、网页浏览、时间操作、系统相关操作、HTTP连接、URL解析、发送电子邮件和短信等功能。

  1. BrushTicket 类初始化:
class BrushTicket(object):def __init__(self, passengers, from_time, from_station, to_station, number, seat_type, receiver_mobile, receiver_email):# 初始化实例属性# ...

这部分定义了 BrushTicket 类并初始化了基于提供的参数的实例属性。这些属性包括乘客详细信息、车站信息、出发时间、座位类型、通知联系人和URL等。

  1. 登录功能:
    def do_login(self):self.driver.visit(self.login_url)sleep(1)print('请扫描二维码登录或使用您的账号登录...')while True:if self.driver.url != self.init_my_url:sleep(1)else:break

do_login 方法负责登录网站。它打开登录的URL,等待用户手动登录(可以通过扫描二维码或使用账号登录),并等待登录成功。

  1. 车票预订功能:
    def start_brush(self):self.driver.driver.maximize_window()self.do_login()self.driver.visit(self.ticket_url)try:# ...except Exception as error_info:print(error_info)

start_brush 方法实现了车票预订功能。它最大化浏览器窗口,执行登录操作,然后导航到车票预订页面。它不断查询是否有可用车票,选择所需的座位类型,并尝试为指定的乘客预订车票。它还处理异常情况,并在成功预订时提供通知。

  1. 短信通知:
    def send_sms(self, mobile, sms_info):# ...

send_sms 方法负责发送短信通知。它使用"互亿无线"服务发送测试短信。它接收接收者的手机号码和短信内容作为参数,并返回从服务端收到的响应。

大家都有所体会12306那种神级验证码,即使是聪明如你也不定每次都能把验证码找对找全。然而经过训练后的模型却是可以的,不得不感叹科技强大。当然该程序中并没有涉及到这一识别验证码的核心技术,它只是将这一工作丢给第三方若快平台去做,然后自身利用结果即可。那么若快是如何识别这种神级验证码呢?通过机器学习 训练所需要的模型?笔者在这方面所了解的较少,不能给过多解释。但是这确实是个值得研究的方向。

  1. 邮件通知:
    def send_mail(self, receiver_address, content):# ...

send_mail 方法处理发送电子邮件通知的功能。它使用SMTP协议连接到电子邮件服务器,使用发件人的凭据登录,并向指定的接收者地址发送电子邮件。它包括主题、正文以及发件人/收件人的详细信息。它接收接收者的电子邮件地址和邮件内容作为参数。

注:给我们推送相关消息,需要用户去提供账户和密码,这是个冒险的尝试,避免不了信息泄露的可能。

  1. 主程序执行:
if __name__ == '__main__':# 用户输入和初始化# ...# 开始预订车票ticket = BrushTicket(passengers, from_time, from_station, to_station, number, seat_type, receiver_mobile, receiver_email)ticket.start_brush()

主程序执行部分接收用户输入以获取预订车票所需的各个参数,使用提供的值初始化 BrushTicket 对象,并调用 start_brush 方法开始预订车票的过程。

注意!!!以下是Python完整代码

欢迎前往公众号:每日治愈系列,获取更多资源!


import re
from splinter.browser import Browser
from time import sleep
import sys
import httplib2
from urllib import parse
import smtplib
from email.mime.text import MIMEText
import timeclass BrushTicket(object):"""买票类及实现方法"""def __init__(self, passengers, from_time, from_station, to_station, number, seat_type, receiver_mobile,receiver_email):"""定义实例属性,初始化"""# 乘客姓名self.passengers = passengers# 起始站和终点站self.from_station = from_stationself.to_station = to_station# 乘车日期self.from_time = from_time# 车次编号self.number = number.capitalize()# 座位类型所在td位置if seat_type == '商务座特等座':seat_type_index = 1seat_type_value = 9elif seat_type == '一等座':seat_type_index = 2seat_type_value = 'M'elif seat_type == '二等座':seat_type_index = 3seat_type_value = 0elif seat_type == '高级软卧':seat_type_index = 4seat_type_value = 6elif seat_type == '软卧':seat_type_index = 5seat_type_value = 4elif seat_type == '动卧':seat_type_index = 6seat_type_value = 'F'elif seat_type == '硬卧':seat_type_index = 7seat_type_value = 3elif seat_type == '软座':seat_type_index = 8seat_type_value = 2elif seat_type == '硬座':seat_type_index = 9seat_type_value = 1elif seat_type == '无座':seat_type_index = 10seat_type_value = 1elif seat_type == '其他':seat_type_index = 11seat_type_value = 1else:seat_type_index = 7seat_type_value = 3self.seat_type_index = seat_type_indexself.seat_type_value = seat_type_value# 通知信息self.receiver_mobile = receiver_mobileself.receiver_email = receiver_email# 新版12306官网主要页面网址self.login_url = 'https://kyfw.12306.cn/otn/resources/login.html'self.init_my_url = 'https://kyfw.12306.cn/otn/view/index.html'self.ticket_url = 'https://kyfw.12306.cn/otn/leftTicket/init?linktypeid=dc'# 浏览器驱动信息,驱动下载页:https://sites.google.com/a/chromium.org/chromedriver/downloadsself.driver_name = 'chrome'self.driver = Browser(driver_name=self.driver_name)def do_login(self):"""登录功能实现,手动识别验证码进行登录"""self.driver.visit(self.login_url)sleep(1)# 选择登陆方式登陆print('请扫码登陆或者账号登陆……')while True:if self.driver.url != self.init_my_url:sleep(1)else:breakdef start_brush(self):"""买票功能实现"""# 浏览器窗口最大化self.driver.driver.maximize_window()# 登陆self.do_login()# 跳转到抢票页面self.driver.visit(self.ticket_url)try:print('开始刷票……')# 加载车票查询信息self.driver.cookies.add({"_jc_save_fromStation": self.from_station})self.driver.cookies.add({"_jc_save_toStation": self.to_station})self.driver.cookies.add({"_jc_save_fromDate": self.from_time})self.driver.reload()count = 0while self.driver.url == self.ticket_url:try:self.driver.find_by_text('查询').click()except Exception as error_info:print(error_info)sleep(1)continuesleep(0.2)count += 1local_date = time.strftime("%Y-%m-%d %H:%M:%S", time.localtime())print('第%d次点击查询……[%s]' % (count, local_date))try:current_tr = self.driver.find_by_xpath('//tr[@datatran="' + self.number + '"]/preceding-sibling::tr[1]')if current_tr:if current_tr.find_by_tag('td')[self.seat_type_index].text == '--':print('无此座位类型出售,已结束当前刷票,请重新开启!')sys.exit(1)elif current_tr.find_by_tag('td')[self.seat_type_index].text == '无':print('无票,继续尝试……')sleep(1)else:# 有票,尝试预订print('刷到票了(余票数:' + str(current_tr.find_by_tag('td')[self.seat_type_index].text) + '),开始尝试预订……')current_tr.find_by_css('td.no-br>a')[0].click()sleep(1)key_value = 1for p in self.passengers:if '()' in p:p = p[:-1] + '学生' + p[-1:]# 选择用户print('开始选择用户……')self.driver.find_by_text(p).last.click()# 选择座位类型print('开始选择席别……')if self.seat_type_value != 0:self.driver.find_by_xpath("//select[@id='seatType_" + str(key_value) + "']/option[@value='" + str(self.seat_type_value) + "']").first.click()key_value += 1sleep(0.2)if p[-1] == ')':self.driver.find_by_id('dialog_xsertcj_ok').click()print('正在提交订单……')self.driver.find_by_id('submitOrder_id').click()sleep(2)# 查看放回结果是否正常submit_false_info = self.driver.find_by_id('orderResultInfo_id')[0].textif submit_false_info != '':print(submit_false_info)self.driver.find_by_id('qr_closeTranforDialog_id').click()sleep(0.2)self.driver.find_by_id('preStep_id').click()sleep(0.3)continueprint('正在确认订单……')self.driver.find_by_id('qr_submit_id').click()print('预订成功,请及时前往支付……')# 发送通知信息self.send_mail(self.receiver_email, '恭喜您,抢到票了,请及时前往12306支付订单!')self.send_sms(self.receiver_mobile, '您的验证码是:1230。请不要把验证码泄露给其他人。')else:print('不存在当前车次【%s】,已结束当前刷票,请重新开启!' % self.number)sys.exit(1)except Exception as error_info:print(error_info)# 跳转到抢票页面self.driver.visit(self.ticket_url)except Exception as error_info:print(error_info)def send_sms(self, mobile, sms_info):"""发送手机通知短信,用的是-互亿无线-的测试短信"""host = "106.ihuyi.com"sms_send_uri = "/webservice/sms.php?method=Submit"account = "C59782899"pass_word = "19d4d9c0796532c7328e8b82e2812655"params = parse.urlencode({'account': account, 'password': pass_word, 'content': sms_info, 'mobile': mobile, 'format': 'json'})headers = {"Content-type": "application/x-www-form-urlencoded", "Accept": "text/plain"}conn = httplib2.HTTPConnectionWithTimeout(host, port=80, timeout=30)conn.request("POST", sms_send_uri, params, headers)response = conn.getresponse()response_str = response.read()conn.close()return response_strdef send_mail(self, receiver_address, content):"""发送邮件通知"""# 连接邮箱服务器信息host = 'smtp.163.com'port = 25sender = 'gxcuizy@163.com'  # 你的发件邮箱号码pwd = '******'  # 不是登陆密码,是客户端授权密码# 发件信息receiver = receiver_addressbody = '<h2>温馨提醒:</h2><p>' + content + '</p>'msg = MIMEText(body, 'html', _charset="utf-8")msg['subject'] = '抢票成功通知!'msg['from'] = sendermsg['to'] = receivers = smtplib.SMTP(host, port)# 开始登陆邮箱,并发送邮件s.login(sender, pwd)s.sendmail(sender, receiver, msg.as_string())if __name__ == '__main__':# 乘客姓名passengers_input = input('请输入乘车人姓名,多人用英文逗号“,”连接,(例如单人“张三”或者多人“张三,李四”,如果学生的话输入“王五()”):')passengers = passengers_input.split(",")while passengers_input == '' or len(passengers) > 4:print('乘车人最少1位,最多4位!')passengers_input = input('请重新输入乘车人姓名,多人用英文逗号“,”连接,(例如单人“张三”或者多人“张三,李四”):')passengers = passengers_input.split(",")# 乘车日期from_time = input('请输入乘车日期(例如“2018-08-08”):')date_pattern = re.compile(r'^\d{4}-\d{2}-\d{2}$')while from_time == '' or re.findall(date_pattern, from_time) == []:from_time = input('乘车日期不能为空或者时间格式不正确,请重新输入:')# 城市cookie字典city_list = {'lz':'%u5170%u5DDE%2CLZJ',#兰州'zz':'%u90D1%u5DDE%2CZZF',#郑州'pds':'%u5E73%u9876%u5C71%2CPEN',#平顶山'wh':'%u829C%u6E56%2CWHH',#芜湖}# 出发站from_input = input('请输入出发站,只需要输入首字母就行:')while from_input not in city_list.keys():from_input = input('出发站不能为空或不支持当前出发站(如有需要,请联系管理员!),请重新输入:')from_station = city_list[from_input]# 终点站to_input = input('请输入终点站,只需要输入首字母就行:')while to_input not in city_list.keys():to_input = input('终点站不能为空或不支持当前终点站(如有需要,请联系管理员!),请重新输入:')to_station = city_list[to_input]# 车次编号number = input('请输入车次号(例如“K1438”):')while number == '':number = input('车次号不能为空,请重新输入:')# 座位类型seat_type = input('请输入座位类型(例如“软卧”):')while seat_type == '':seat_type = input('座位类型不能为空,请重新输入:')# 抢票成功,通知该手机号码receiver_mobile = input('请预留一个手机号码,方便抢到票后进行通知(例如:18888888888):')mobile_pattern = re.compile(r'^1{1}\d{10}$')while receiver_mobile == '' or re.findall(mobile_pattern, receiver_mobile) == []:receiver_mobile = input('预留手机号码不能为空或者格式不正确,请重新输入:')receiver_email = input('请预留一个邮箱,方便抢到票后进行通知(例如:test@163.com):')while receiver_email == '':receiver_email = input('预留邮箱不能为空,请重新输入:')# 开始抢票ticket = BrushTicket(passengers, from_time, from_station, to_station, number, seat_type, receiver_mobile,receiver_email)ticket.start_brush()

如若有各种问题,欢迎留言讨论!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/37953.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

chatgpt赋能python:Python怎么抢票?

Python怎么抢票&#xff1f; Python是一种伟大的编程语言&#xff0c;因为它可以使我们的生活更加便利。有10年python编程经验的工程师会告诉你&#xff0c;利用Python编程可以轻松地抢到大热节目或演出的票。本文将介绍使用Python编写抢票机器人的方法。 概述 抢票机器人是…

chatgpt赋能python:Python自动抢票:让你的购票经历更加简单便捷!

Python自动抢票&#xff1a;让你的购票经历更加简单便捷&#xff01; 随着互联网的发展&#xff0c;越来越多的人选择在网上购买火车、飞机等交通工具的票。但是&#xff0c;一些火爆的车次、航班往往在开售后仅仅几秒钟内就被抢完&#xff0c;让很多想出行的人非常苦恼。在这…

基于微信小程序的餐厅点餐软件设计及开发

目 录 摘要 I Abstract II 1 前言 1 1.1 选题背景 1 1.2 研究的目的和意义 1 2 相关技术简介 3 2.1 系统的实现架构 3 2.2 系统使用的技术 3 2.2.1 Eclipse 3 2.2.2 Java 4 2.2.3 MySQL简介 5 2.2.4 微信小程序简介 6 2.3 系统使用的开发环境 6 3 系统需求分析 7 3.1 功能需求 …

餐饮行业移动管理系统—Pad点餐系统

餐饮行业移动管理系统—Pad点餐系统 员工可通过PC端查询或管理饭店信息&#xff0c;即使更新信息&#xff0c;客户可以进行方便快捷的点菜操作。 功能要求&#xff1a; PC端功能&#xff1a;管理菜谱&#xff0c;餐厅&#xff0c;员工&#xff0c;订单信息&#xff1b;服务端…

基于Android移动终端的微型餐饮管理系统的设计与实现2-侧滑菜单

上周发了《 基于Android移动终端的微型餐饮管理系统的设计与实现》第一章,虽然是个简介,但是居然上了首页推荐,还有朋友评论了。写了这么久CSDN,还是第一次有人评论我的文章,真是受宠若惊,长期以来,我一直都以为,我玩的是CSDN单机版。当然,这也说明,我过去写的东西都…

安卓移动开发技术--微信界面设计

1.内容&#xff1a;请根据课程实现App门户界面框架设计&#xff0c;至少包含4个tab页&#xff0c;能实现tab页之间的点击切换&#xff1b; 2.技术&#xff1a;使用布局和分段&#xff0c;对控件进行点击监听 实现界面展示&#xff1a; 一.界面布局分析 1.先对button.xml界面…

移动开发--类vx界面

一、开发目标 创建一个类似vx的界面&#xff0c;具有vx、通讯录、发现、我 四个tab&#xff0c;可通过点击实现切换 二、代码解析 写4个tab&#xff0c;用作vx 、通讯录、发现、我四个界面 一个top.xml 一个bottom.xml 一个framelayout作为容器 mainactivity如下&#x…

【餐厅点餐平台|四】UI设计+效果展示

餐厅点餐平台导航 【餐厅点餐平台&#xff5c;一】项目描述需求分析 https://blog.csdn.net/weixin_46291251/article/details/126414430 【餐厅点餐平台&#xff5c;二】总体设计 https://blog.csdn.net/weixin_46291251/article/details/126422811 【餐厅点餐平台&#xff5…

【餐饮】智慧餐厅原型模板,餐饮APP,餐饮后台管理系统,Axure设计餐饮APP

软件版本&#xff1a;Axure 8.0&#xff08;兼容9和10&#xff09; 作品介绍&#xff1a; 作品包括用户端、员工端以及商户管理&#xff08;后台管理&#xff09; 客户端&#xff1a; 外卖点餐&#xff1a;菜品列表、菜品详情、确认订单、地址管理、修改电话、支付订单 堂食点…

基于Androidstudio餐厅点餐选座系统

完成“餐厅点餐系统”的设计。餐厅点餐系统是一个适用于餐饮行业和消费者的软件&#xff0c;顾客可以使用该系统自动点餐&#xff0c;也可到店后由服务人员点餐&#xff0c;系统管理员进行后台管理。 build.gradle (Module: app) 包含当前项目的applicationId、最小适配的Andro…

【花雕学AI】ChatGPT能用表情包猜电影,你能猜出来吗?揭秘它的神奇「涌现」能力

关于作者斯蒂芬 我是田纳西州纳什维尔的一名科学作家&#xff0c;负责数学、物理学、天文学和癌症研究。我的书Math Art: Truth, Beauty, and Equations 将于 2019 年 4 月出版。我在后院改建的办公室棚子里工作。我是范德比尔特大学的驻校作家&#xff0c;教授科学传播课程。 …

chatgpt赋能python:Python数据分析中如何快速取到一列数据

Python 数据分析中如何快速取到一列数据 在 Python 数据分析中&#xff0c;我们经常需要取到表格中的某一列数据进行分析或可视化。下面介绍了几种方法&#xff0c;可帮助您快速有效地取得所需要的数据。 1. 使用 Pandas 包获取数据 Pandas 是 Python 中非常常用的数据分析库…

【花雕学AI】09:发挥ChatGPT最大潜力——产生高质量内容的九种方法和建议

人工智能&#xff08;AI&#xff09;是当今科技领域最热门和最有前景的话题之一&#xff0c;它已经渗透到了我们生活和工作的方方面面&#xff0c;给我们带来了许多便利和惊喜。而在AI的众多分支中&#xff0c;自然语言处理&#xff08;NLP&#xff09;是最贴近人类的一个领域&…

AI教父Hinton与OpenAI CEO Sam Altman领头预警:AI可能灭绝人类!

整理 | 屠敏 出品 | CSDN&#xff08;ID&#xff1a;CSDNnews&#xff09; 经过不到一年的时间&#xff0c;AI 的发展超乎所有人的想象&#xff0c;也大有失控的风险。 就在今天&#xff0c;全球部分顶尖的 AI 研究员、工程师和 CEO 就他们认为 AI 对人类构成的生存威胁发出了新…

多位知名学者最新警告「AI 可能灭绝人类」,ChatGPT 之父和 AI 教父都参与联名,如何理解?

警告“AI可能灭绝人类”是指一些知名学者和专家对于未来人工智能发展的担忧&#xff0c;他们认为如果AI发展得不受控制&#xff0c;可能会导致人类的灭绝。其中&#xff0c;ChatGPT之父和AI教父分别指的是OpenAI的创始人和AI领域的一些权威人物。 这种担忧主要源于以下几个方…

什么是ChatGPT?GPT4和3.5有什么不同

相信今天大家都被GPT刷屏了&#xff0c;我可以使用GPT帮我写文章框架&#xff0c;诗歌&#xff0c;作文等等。 那么&#xff0c;GPT究竟是什么呢&#xff1f; ChatGPT全称为“chat Generative Pre-trained Transformer”&#xff0c;翻译成中文就是生成型预训练变换模型&#…

不直播不露脸也能做短视频变现,想挣点生活费试试这些玩法

大家好&#xff0c;我是我赢助手短视频运营&#xff0c;最近一直有小伙伴问我&#xff0c;做了好久的短视频一直不赚钱&#xff0c;今天总结了一下&#xff0c;做了90天短视频还没赚了试试这5种易变现的玩法。 新手不直播不露脸也能做短视频变现&#xff0c;想在斗音挣点生活费…

实不相瞒,我做海外TikTok搬运视频一年的收入,可能是你10年的工资

被疫情偷走的这几年&#xff0c;听到的关键词几乎都是“难”&#xff0c;“很难”&#xff0c;“非常难”。 裁员成常态&#xff0c;收入大缩水&#xff0c;但花钱的地方却越来越多。 天天熬&#xff0c;夜夜熬。 最终换来的&#xff0c;是口袋空荡荡&#xff0c;日子紧巴巴。 …

短视频获客达人软件详情,精准截流app

互联网99%的项目离不开流量&#xff0c;流量所在之处&#xff0c;必有金钱相随。对于创业者来讲&#xff0c;更要注重精准引流的积累&#xff0c;或许引流没泛流量简单粗暴&#xff0c;但是賺钱更简单&#xff0c;选择互联网创业不是急功近利的儿戏&#xff0c;创业项目就应该有…

用Java代码实现双色球彩票

模拟整个双色球彩票的购买、开奖和中奖流程 一、双色球玩法规则&#xff1a; 1、投注&#xff1a; &#xff08;1&#xff09;双色球投注区分为红色球号码区和蓝色球号码区&#xff0c;&#xff08;2&#xff09;红色球号码区由1-33共三十三个号码组成&#xff0c;蓝色球号码…