一年一度的春運又來了,
今年我自己寫了個搶票腳本。
python +splinter自動刷新?lián)屍保梢猿晒尩剑ㄒ蕾囎约旱木W絡環(huán)境太厲害,還有機器的好壞),
但是感覺不是很完美,
有大神請指導完善一下(或者有沒有別的好點的思路)
不勝感謝
# -*- coding: utf-8 -*- """ @author: liuyw """ from splinter.browser import Browser from time import sleep import traceback import time, sys class huoche(object): """docstring for huoche""" driver_name="" executable_path="" #用戶名,密碼 username = u"[email protected]" passwd = u"xxxx" # cookies值得自己去找, 下面兩個分別是上海, 太原南 starts = u"%u4E0A%u6D77%2CSHH" ends = u"%u592A%u539F%2CTYV" # 時間格式2018-01-19 dtime = u"2018-01-19" # 車次,選擇第幾趟,0則從上之下依次點擊 order = 0 ###乘客名 users = [u"xxx",u"xxx"] ##席位 xb = u"二等座" pz=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" buy="https://kyfw.12306.cn/otn/confirmPassenger/initDc" login_url="https://kyfw.12306.cn/otn/login/init" def __init__(self): self.driver_name="chrome" self.executable_path="/usr/local/bin/chromedriver" def login(self): self.driver.visit(self.login_url) self.driver.fill("loginUserDTO.user_name", self.username) # sleep(1) self.driver.fill("userDTO.password", self.passwd) print u"等待驗證碼,自行輸入..." while True: if self.driver.url != self.initmy_url: sleep(1) else: break def start(self): self.driver=Browser(driver_name=self.driver_name,executable_path=self.executable_path) self.driver.driver.set_window_size(1400, 1000) self.login() # sleep(1) self.driver.visit(self.ticket_url) try: print u"購票頁面開始..." # sleep(1) # 加載查詢信息 self.driver.cookies.add({"_jc_save_fromStation": self.starts}) self.driver.cookies.add({"_jc_save_toStation": self.ends}) self.driver.cookies.add({"_jc_save_fromDate": self.dtime}) self.driver.reload() count=0 if self.order!=0: while self.driver.url==self.ticket_url: self.driver.find_by_text(u"查詢").click() count += 1 print u"循環(huán)點擊查詢... 第 %s 次" % count # sleep(1) try: self.driver.find_by_text(u"預訂")[self.order - 1].click() except Exception as e: print e print u"還沒開始預訂" continue else: while self.driver.url == self.ticket_url: self.driver.find_by_text(u"查詢").click() count += 1 print u"循環(huán)點擊查詢... 第 %s 次" % count # sleep(0.8) try: for i in self.driver.find_by_text(u"預訂"): i.click() sleep(1) except Exception as e: print e print u"還沒開始預訂 %s" %count continue print u"開始預訂..." # sleep(3) # self.driver.reload() sleep(1) print u"開始選擇用戶..." for user in self.users: self.driver.find_by_text(user).last.click() print u"提交訂單..." sleep(1) # self.driver.find_by_text(self.pz).click() # self.driver.find_by_id("").select(self.pz) # # sleep(1) # self.driver.find_by_text(self.xb).click() # sleep(1) self.driver.find_by_id("submitOrder_id").click() # print u"開始選座..." # self.driver.find_by_id("1D").last.click() # self.driver.find_by_id("1F").last.click() sleep(1.5) print u"確認選座..." self.driver.find_by_id("qr_submit_id").click() except Exception as e: print e if __name__ == "__main__": huoche=huoche() huoche.start()
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉載請注明本文地址:http://systransis.cn/yun/41129.html
摘要:最近在學,所以用寫了這個搶票腳本,分享出來,與大家共同交流和學習,有不對的地方,請大家多多指正。 最近在學Python,所以用Python寫了這個12306搶票腳本,分享出來,與大家共同交流和學習,有不對的地方,請大家多多指正。話不多說,進入正題: 在進入正題之前,我想說明一下,由于12306官網的改版更新,所以腳本作了一點小小的變化,具體修改后的源碼,可以到GitHub上面查看……新...
摘要:背景訂票網站韻動株洲游泳館訂票網站訂票規(guī)則用戶當天,預約第二日免費游泳公益券領取資格,每位用戶每天只能預訂一張如有余票當天也可預訂。 前言 暑假閑來無事,每天上午的寶貴時間想去游泳,減減肚子,練練耐力,正好我們那個地方游泳館上午提供免費的票,但是,需要前一天早上七點開始預定第二天上午的免費游泳票。往年暑假,我是每天早上六點五十五準時起床,眼睛半睜不睜的等著七點一到,立馬搶票!搶完一臉解...
摘要:但今年各種搶票軟件的橫行,還有官方出的加速包,導致連黃牛都不敢保證能買到票。今天我就給大家介紹一個開源的搶票程序,親測有效我身邊已經有很多好友,通過這個程序搶到車票了。這個庫是用來在上同步校準當地時間的。 showImg(https://segmentfault.com/img/remote/1460000017814865); 閱讀文本大概需要 6.6 分鐘。 又到了一年一度的搶票大...
摘要:什么是網絡爬蟲通俗理解就是一個模擬人請求網站的程序,可以自動請求網頁并將所定義需求的數據抓取下來,然后提取有價值的數據。主要將網頁信息下載到搜索引擎存儲,形成一個互聯(lián)網內容的鏡像備份聚焦爬蟲面向特定需求的一種爬蟲。 爬蟲開始 爬蟲的實際例子 搜索引擎:關鍵字匹配提取,前提是要將所有的頁面爬一遍,然后存到自己的服務器,當用戶驚醒搜索的時候,根據自己的搜索內容,搜索引擎將用戶搜索信息返回...
閱讀 3679·2021-11-24 09:39
閱讀 1288·2021-09-30 09:48
閱讀 3276·2021-09-09 11:51
閱讀 2900·2021-09-08 10:41
閱讀 1340·2019-08-30 14:06
閱讀 2809·2019-08-30 14:01
閱讀 884·2019-08-29 17:11
閱讀 3183·2019-08-29 15:37