Python3脚本抢票

一直很想尝试一下电脑跑脚本,抢票就是一个很好的例子。于是在网上找呀找,终于找到了一个可以运行的12306抢票脚本。虽然因为12306的图片验证而有些阻碍。但我觉得代码跑起来的整体体验非常好。

感谢一位博主提供的代码:https://www.cnblogs.com/lizm166/p/8191305.html

1.Chromedriver 驱动的下载地址如下: 
http://chromedriver.storage.googleapis.com/index.html

下载好后将.exe文件放置在C:\Windows\System32 中

2.代码

#python3.x

from splinter.browser import Browser
from time import sleep
# traceback模块被用来跟踪异常返回信息
import traceback
# 设定用户名、密码
username = u"用户名"
passwd = u"密码"
# 起始站点和乘车时间的cookies值要去找;
# 方法:先登录一下12306,输入地点日期什么的查询一下,然后在chrome浏览器中按F12,出现如下页面,在Application选项里找到相应的值。
# 表格中的cookie值:
#_jc_save_fromeStation的值为出发地
#_jc_save_toSatation的值为目的地
#_jc_save_fromDate 出发日期
#_jc_save_toDate返程日期
# 实例中用的是:北京 到 西安 2018-09-16
from_station = u"%u5317%u4EAC%2CBJP"
to_station = u"%u897F%u5B89%2CXAY"
# 时间格式2018-01-25
from_date = u"2018-09-16"
# 车次,选择第几趟,0则从上之下依次点击
order = 0
# 设定乘客姓名
ticketer = u"乘客姓名"
# 设定网址
ticket_url = "https://kyfw.12306.cn/otn/leftTicket/init"
login_url = "https://kyfw.12306.cn/otn/login/init"
initmy_url = "https://kyfw.12306.cn/otn/index/initMy12306"

# 登录网站
def login():
    #点击当前页面的"登录"
    bwr.find_by_text(u"登录").click()
    sleep(3)
    #fill填充搜索框的内容,username。name=loginUserDTO.user_name的元素。
    bwr.fill("loginUserDTO.user_name", username)
    sleep(1)
    bwr.fill("userDTO.password", passwd)
    sleep(1)
    print(u"等待验证码,自行输入...")
    #登录手动输入验证码,并登录系统
    while True:
        #判断当前的url是否已经进入系统
        if bwr.url != initmy_url:
            sleep(1)
        else:
            break
# 购票
def getTickt():
    global bwr
    # 使用splinter打开chrome浏览器
    bwr=Browser(driver_name="chrome")
    # splinter打开浏览器(返回购票页面)
    bwr.visit(ticket_url)
    while bwr.is_text_present(u"登录"):
        sleep(1)
        login()
        #判断是否已经进入系统
        if bwr.url == initmy_url:
            break
    try:
        print(u"购票页面...")
        # splinter打开浏览器(跳回购票页面)
        bwr.visit(ticket_url)
        # 加载查询信息
        bwr.cookies.add({"_jc_save_fromStation": from_station})
        bwr.cookies.add({"_jc_save_toStation": to_station})
        bwr.cookies.add({"_jc_save_fromDate": from_date})
        bwr.reload()
        sleep(2)
        count=0
        # 循环点击预订
        if order != 0:
            while bwr.url == ticket_url:
                bwr.find_by_text(u"查询").click()
                count += 1
                print(u"循环点击查询... 第 %s 次" % count)
                sleep(1)
                try:
                    bwr.find_by_text(u"预订")[order - 1].click()
                except:
                    print(u"还没开始预订")
                    continue
        else:
            while bwr.url == ticket_url:
                 bwr.find_by_text(u"查询").click()
                 count += 1
                 print(u"循环点击查询... 第 %s 次" % count)
                 sleep(1)
                 try:
                     for i in bwr.find_by_text(u"预订"):
                         i.click()
                         sleep(1)
                 except:
                     print(u"还没开始预订")
                     continue
        sleep(1)
        # 可以通过修改sleep的参数来调整延时, 但延时不要太低, 防止被12306网站认为是刷票屏蔽掉.
        bwr.find_by_text(ticketer)[0].click()
        sleep(1)
        bwr.find_by_text(u"提交订单").click()
        sleep(1)
        #bwr.find_by_id(u"qr_submit_id").click()
        print(u"成功抢到一张宝贵的票")
    except Exception as e:
         print(traceback.print_exc())

if __name__ == "__main__":
    getTickt()

 

你可能感兴趣的:(笨办法学python)