当前位置: 首页 > news >正文

制作网站的专业公司北京建设工程公司

制作网站的专业公司,北京建设工程公司,网站开发 绩效考核,网站建设费 摊销处理提示#xff1a;文章写完后#xff0c;目录可以自动生成#xff0c;如何生成可参考右边的帮助文档 python实现自动登录12306抢票 -- selenium 前言其实网上也出现了很多12306的代码#xff0c;但是都不是最新的#xff0c;我也是从网上找别人的帖子#xff0c;看B站视频文章写完后目录可以自动生成如何生成可参考右边的帮助文档 python实现自动登录12306抢票 -- selenium 前言其实网上也出现了很多12306的代码但是都不是最新的我也是从网上找别人的帖子看B站视频然后写成了这个程序想分享一下。其中我会说自己遇到的问题以及自己的一个改进。 一、遇到的问题1.url-正确的表头就是首先url不要写错了然后一定要加正确的表头才可以拿到数据就是我日期填写错误然后生成的url就有问题浪费了好多时间。日期2024-01-09 不要加两个杠。。。2.注意用网页显示的user-agent:3.拿到车票信息的json数据--代码展示4. 12306的城市对应的代码json文件大家可以去网上找下然后自己编程写一下我这个也花了一些时间锻炼自己4.对拿到的车次json数据进行可视化处理也生成一个列表信息代码如下5.程序进入到自动化代码 -- 自动登录 --自动抢票这里要注意有些操作一定要有时间等待time.sleep(2)等是不可以删除的否则会报错因为操作太快浏览器没有反应过来。至此这个程序完全结束了。这也是最近春节要抢票我特意写的。主要都是学习别人的代码但是有几个改进是自己学了爬虫然后结合网页的变化很多程序是20212022的现在12306的网页有所改变所写的。 二、改进1.xpath语法中id 或者说可以元素但是selenium不可以要拆成两部来写。而且新的selenium语法和前几年的也有所区别。2.预定按钮的元素定位我没有写死可以自己定义也就是可以自己选择预定那躺车比如13411等随便选择。因为这里是用了xpath语法去找到了所有的预订按钮。这个num你也可以放在login.json当中这样更方面抢票。login.json就是一个字典序列我是将要填写的东西都放进去。这样不用手动填写。3.源代码完整展示 三、进阶--展望1.首先可以将自动化操作用try--except这样不会一直报错更为规范。2.免登录因为登录其实要验证码这样抢票也不方便。于是我就又继续学习了一些发现了两种方法一是可以保存浏览器的数据因为selenium每次打开的是一个新的程序但是我们可以通过设置参数让他打开是有记忆的但是没有用。第二种是cookie,是没有什么问题的目前已经实现接下尝试各种方法的cookie看行不行。后续我会发此程序。3.多线程多进程主要我已经实现cookie免登录我想着是否可以打开多个页面然后多个账号一起抢他们所需要的票呢。 总结1.最开始跟着写这个程序只会照着抄然后根本不懂后面就是差了一点点成功也不会找错误。2.后面学习了一下爬虫更明白一点语法以及自己也更会如何定位元素了。还有就是request的一个请求这些代码也更看得懂了3.想着结合多线程然后实现批量抢票同时也希望代价的容错率高也就是说在自动化不用点几下程序就不行了让它可以有更好的性能。-- 未来学习的一个点。加油 前言 其实网上也出现了很多12306的代码但是都不是最新的我也是从网上找别人的帖子看B站视频然后写成了这个程序想分享一下。其中我会说自己遇到的问题以及自己的一个改进。 提示以下是本篇文章正文内容下面案例可供参考 一、遇到的问题 1.url-正确的表头就是首先url不要写错了然后一定要加正确的表头才可以拿到数据就是我日期填写错误然后生成的url就有问题浪费了好多时间。日期2024-01-09 不要加两个杠。。。 2.注意用网页显示的user-agent: 3.拿到车票信息的json数据–代码展示 import requests from prettytable import PrettyTable # 下面的模块就是打开浏览器的操作模块 from selenium import webdriver from selenium.webdriver.common.keys import Keys# 获取浏览器的用户数据 # chrome chrome://version/ # 个人资料路径 C:\Users\hl\AppData\Local\Temp\scoped_dir18416_1206036739\Default # 路径的Default要去掉 path rD:\game\chromedriver.exe user_data_dir rC:\Users\hl\AppData\Local\Temp\scoped_dir18416_1206036739from pypinyin import pinyin, Style import json import time 发送请求模拟浏览器对于url地址发送请求根据用户自行输入相关信息进行查票搜索 # 读取城市文件 f open(city_all.json, encodingutf-8).read() city_data json.loads(f) print(city_data)# 输入出发和目的城市 # 输入时间 train_date 2025-01-09 from_city input(请输出你出发的城市:) to_city input(请输出你要出行的城市:) print(city_data[from_city]) print(city_data[to_city])headers {user-agent:Mozilla/5.0 (Linux; Android 6.0; Nexus 5 Build/MRA58N) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/131.0.0.0 Mobile Safari/537.36,}# 请求网址 # https://kyfw.12306.cn/otn/leftTicket/queryG?leftTicketDTO.train_date2025-01-06leftTicketDTO.from_stationSZQleftTicketDTO.to_stationEFGpurpose_codesADULT url fhttps://kyfw.12306.cn/otn/leftTicket/queryG?leftTicketDTO.train_date{train_date}leftTicketDTO.from_station{city_data[from_city]}leftTicketDTO.to_station{city_data[to_city]}purpose_codesADULT# 发送请求 使用request response requests.get(urlurl, headersheaders) print(url) print(response.status_code) print(response.text) # 获取数据 json_data response.json() 4. 12306的城市对应的代码json文件大家可以去网上找下然后自己编程写一下我这个也花了一些时间锻炼自己 4.对拿到的车次json数据进行可视化处理也生成一个列表信息代码如下 import requests from prettytable import PrettyTable # 下面的模块就是打开浏览器的操作模块 from selenium import webdriver from selenium.webdriver.common.keys import Keys# 获取浏览器的用户数据 # chrome chrome://version/ # 个人资料路径 C:\Users\hl\AppData\Local\Temp\scoped_dir18416_1206036739\Default # 路径的Default要去掉 path rD:\game\chromedriver.exe user_data_dir rC:\Users\hl\AppData\Local\Temp\scoped_dir18416_1206036739from pypinyin import pinyin, Style import json import time 发送请求模拟浏览器对于url地址发送请求根据用户自行输入相关信息进行查票搜索 # 读取城市文件 f open(city_all.json, encodingutf-8).read() city_data json.loads(f) print(city_data)# 输入出发和目的城市 # 输入时间 train_date 2025-01-09 from_city 深圳 to_city 广州 print(city_data[from_city]) print(city_data[to_city])headers {cookie:f_uab_collina173526990403562156621352; JSESSIONID1B8F19FC6675BDA9782FEA7B06BDC256; route9036359bb8a8a461c164a04f8f50b252; BIGipServerotn1725497610.24610.0000; BIGipServerpassport1005060362.50215.0000; guidesStatusoff; highContrastModedefaltMode; cursorStatusoff; _jc_save_fromStation%u6DF1%u5733%2CSZQ; _jc_save_toStation%u4FE1%u4E30%2CEFG; _jc_save_fromDate{train_date}; _jc_save_wfdc_flagdc; _jc_save_toDate2024-12-28,user-agent:Mozilla/5.0 (Linux; Android 6.0; Nexus 5 Build/MRA58N) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/131.0.0.0 Mobile Safari/537.36,}# 请求网址 # https://kyfw.12306.cn/otn/leftTicket/queryG?leftTicketDTO.train_date2025-01-06leftTicketDTO.from_stationSZQleftTicketDTO.to_stationEFGpurpose_codesADULT url fhttps://kyfw.12306.cn/otn/leftTicket/queryG?leftTicketDTO.train_date{train_date}leftTicketDTO.from_station{city_data[from_city]}leftTicketDTO.to_station{city_data[to_city]}purpose_codesADULT# 发送请求 使用request response requests.get(urlurl, headersheaders) print(url) print(response.status_code) print(response.text) # 获取数据 json_data response.json()# 解析数据--字典取值 result json_data[data][result]# 实例化对象 tb PrettyTable() tb.field_names [序号,车次,出发时间,到达时间,耗时,特等座,一等座,二等座,软卧,硬卧,硬座,无座, ]# 定义一个打印序号page page 1 # for循环遍历提取列表里面的元素 for i in result:# 字符串分割返回列表index i.split(|)# 通过列表索引位置取值num index[3] # 车次star_time index[8] # 出发时间arrive_time index[9] # 到达时间use_time index[10] # 耗时special_class index[32] # 特等座frist_class index[31] # 一等座second_class index[30] # 二等座hard_sleeper index[28] # 硬卧hard_seat index[29] # 硬座no_seat index[26] # 无座soft_sleeper index[23]# 软卧dict {序号:page,车次:num,出发时间:star_time,到达时间:arrive_time,耗时:use_time,特等座:special_class,一等座:frist_class,二等座:second_class,软卧:soft_sleeper,硬卧:hard_sleeper,硬座:hard_seat,无座: no_seat}tb.add_row([page, #序号索引num, # 车次star_time,# 出发时间arrive_time,# 到达时间use_time, # 耗时special_class, # 特等座frist_class, # 一等座second_class,# 二等座soft_sleeper, # 软卧hard_sleeper,# 硬卧hard_seat, # 硬座no_seat,# 无座])page 1 print(tb)5.程序进入到自动化代码 – 自动登录 --自动抢票这里要注意有些操作一定要有时间等待time.sleep(2)等是不可以删除的否则会报错因为操作太快浏览器没有反应过来。 def selenium_login():# 0.配置谷歌浏览器加载项options webdriver.ChromeOptions()options.add_argument(f--user-data-dir{user_data_dir}) # 添加浏览器数剧# 1.将加载项配置到启动浏览器中 打开/创建浏览器对象driver webdriver.Chrome(executable_pathrD:\game\chromedriver.exe, optionsoptions)# 2.输入网址driver.get(https://kyfw.12306.cn/otn/view/index.html)# 3.输入账号 -- 找到账号的输入框 selenium 通过元素面板去定位元素driver.find_element(bycss selector, value#J-userName).send_keys(login[account])# 4.输入密码 -- 找到密码的输入框driver.find_element(bycss selector, value#J-password).send_keys(login[password])# 5.点击登录按钮driver.find_element(bycss selector, value#J-login).click()time.sleep(0.5)# 6.输入身份证后4位driver.find_element(bycss selector, value#id_card).send_keys(login[id_card])# 7.点击获取验证码driver.find_element(bycss selector, value#verification_code).click()# 8.输入验证码code input(请输入验证码)driver.find_element(bycss selector, value#code).send_keys(code)driver.find_element(bycss selector, value#verification_code).click()# 9.点击确认按钮driver.find_element(bycss selector, value#sureClick).click()# 有时候报错是需要延时等待 用 driver.implicitly_wait(10)代码 可以实现加载完就就进行下一步# 而time.sleep(5)则必须等我规定的时间driver.implicitly_wait(5)# 10点击车票预定按钮driver.find_element(bycss selector, value#link_for_ticket).click()# 11.1 选择出发的城市--点击那个框driver.find_element(bycss selector, value#fromStationText).click()# 11.2 选择出发的城市--选择城市driver.find_element(bycss selector, value#fromStationText).send_keys(from_city)# 11.3 选择出发的城市--回车确定driver.find_element(bycss selector, value#fromStationText).send_keys(Keys.ENTER)# 12.1 选择目的的城市--点击那个框driver.find_element(bycss selector, value#toStationText).click()# 12.2 选择目的的城市--选择城市driver.find_element(bycss selector, value#toStationText).send_keys(to_city)# 12.3 选择目的的城市--回车确定driver.find_element(bycss selector, value#toStationText).send_keys(Keys.ENTER)# 13.1 选择出发的日期--点击那个框driver.find_element(bycss selector, value#train_date).clear()# 12.2 选择出发的日期--选择城市driver.find_element(bycss selector, value#train_date).send_keys(train_date)# 12.3 选择出发的日期--回车确定driver.find_element(bycss selector, value#train_date).send_keys(Keys.ENTER)# # 12.4 点击--显示全部可预订的车次# driver.find_element(bycss selector, valueavail_ticket).click()# 12.5 点击查询driver.implicitly_wait(5)driver.find_element(bycss selector, value#query_ticket).click()num int(input(请输入您想要的车次:))# 点击预订按钮 -- 选择要预定的是第几躺车 -- 这个代码没有问题# driver.find_element(bycss selector, value#ticket_65000G279007_01_03 td.no-br).click()# //div//tbody[idqueryLeftTable]/tr[contains(id,ticket)]/id -- 但是selenium的find_elements不可以用id找到元素。ticket_list driver.find_elements(byxpath, value//div//tbody[idqueryLeftTable]/tr[contains(id,ticket)])ticket_num ticket_list[num].get_attribute(id)ticket_pre ticket_num td.no-br# 12.6 点击想要车次的预定按钮driver.find_element(bycss selector, valuef#{ticket_pre}).click()# 13.1 勾选想要的乘车人driver.find_element(bycss selector, value#normalPassenger_0).click()# 13.2 提交订单driver.find_element(bycss selector, value#submitOrder_id).click()driver.implicitly_wait(5)# 13.3 选择靠窗的1F的位置# driver.find_element(bycss selector, value#1F).click() --这种行不通只能下方这种driver.find_element(bycss selector, value#erdeng1 ul:nth-child(4) li:nth-child(2)).click()# 13.4 再次确认提交time.sleep(2)driver.find_element(bycss selector, value#qr_submit_id).click()# driver.find_element(bycss selector, value#qr_submit_id).click()# # 14. 网上支付 -- payButton# driver.find_element(bycss selector, value#payButton).click()# # 15. 取消订单 -- cancelButton# driver.find_element(bycss selector, value#cancelButton).click()至此这个程序完全结束了。这也是最近春节要抢票我特意写的。主要都是学习别人的代码但是有几个改进是自己学了爬虫然后结合网页的变化很多程序是20212022的现在12306的网页有所改变所写的。 二、改进 1.xpath语法中id 或者说可以元素但是selenium不可以要拆成两部来写。而且新的selenium语法和前几年的也有所区别。 # 点击预订按钮 -- 选择要预定的是第几躺车 -- 这个代码没有问题# driver.find_element(bycss selector, value#ticket_65000G279007_01_03 td.no-br).click()# //div//tbody[idqueryLeftTable]/tr[contains(id,ticket)]/id -- 但是selenium的find_elements不可以用id找到元素。ticket_list driver.find_elements(byxpath, value//div//tbody[idqueryLeftTable]/tr[contains(id,ticket)])ticket_num ticket_list[num].get_attribute(id)ticket_pre ticket_num td.no-br2.预定按钮的元素定位我没有写死可以自己定义也就是可以自己选择预定那躺车比如13411等随便选择。因为这里是用了xpath语法去找到了所有的预订按钮。这个num你也可以放在login.json当中这样更方面抢票。login.json就是一个字典序列我是将要填写的东西都放进去。这样不用手动填写。 num int(input(请输入您想要的车次:))# 点击预订按钮 -- 选择要预定的是第几躺车 -- 这个代码没有问题# driver.find_element(bycss selector, value#ticket_65000G279007_01_03 td.no-br).click()# //div//tbody[idqueryLeftTable]/tr[contains(id,ticket)]/id -- 但是selenium的find_elements不可以用id找到元素。ticket_list driver.find_elements(byxpath, value//div//tbody[idqueryLeftTable]/tr[contains(id,ticket)])ticket_num ticket_list[num].get_attribute(id)ticket_pre ticket_num td.no-br login.json的内容展示 3.源代码完整展示 import requests from prettytable import PrettyTable # 下面的模块就是打开浏览器的操作模块 from selenium import webdriver from selenium.webdriver.common.keys import Keys# 获取浏览器的用户数据 # chrome chrome://version/ # 个人资料路径 C:\Users\hl\AppData\Local\Temp\scoped_dir18416_1206036739\Default # 路径的Default要去掉 path rD:\game\chromedriver.exe user_data_dir rC:\Users\hl\AppData\Local\Temp\scoped_dir18416_1206036739from pypinyin import pinyin, Style import json import time 发送请求模拟浏览器对于url地址发送请求根据用户自行输入相关信息进行查票搜索 # 读取城市文件 f open(city_all.json, encodingutf-8).read() city_data json.loads(f) print(city_data)# 输入出发和目的城市 # 输入时间 train_date 2025-01-09 from_city 深圳 to_city 广州 print(city_data[from_city]) print(city_data[to_city])headers {cookie:f_uab_collina173526990403562156621352; JSESSIONID1B8F19FC6675BDA9782FEA7B06BDC256; route9036359bb8a8a461c164a04f8f50b252; BIGipServerotn1725497610.24610.0000; BIGipServerpassport1005060362.50215.0000; guidesStatusoff; highContrastModedefaltMode; cursorStatusoff; _jc_save_fromStation%u6DF1%u5733%2CSZQ; _jc_save_toStation%u4FE1%u4E30%2CEFG; _jc_save_fromDate{train_date}; _jc_save_wfdc_flagdc; _jc_save_toDate2024-12-28,user-agent:Mozilla/5.0 (Linux; Android 6.0; Nexus 5 Build/MRA58N) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/131.0.0.0 Mobile Safari/537.36,}# 请求网址 # https://kyfw.12306.cn/otn/leftTicket/queryG?leftTicketDTO.train_date2025-01-06leftTicketDTO.from_stationSZQleftTicketDTO.to_stationEFGpurpose_codesADULT url fhttps://kyfw.12306.cn/otn/leftTicket/queryG?leftTicketDTO.train_date{train_date}leftTicketDTO.from_station{city_data[from_city]}leftTicketDTO.to_station{city_data[to_city]}purpose_codesADULT# 发送请求 使用request response requests.get(urlurl, headersheaders) print(url) print(response.status_code) print(response.text) # 获取数据 json_data response.json()# 解析数据--字典取值 result json_data[data][result]def print_ticketlist():# 实例化对象tb PrettyTable()tb.field_names [序号,车次,出发时间,到达时间,耗时,特等座,一等座,二等座,软卧,硬卧,硬座,无座,]# 定义一个打印序号pagepage 1# for循环遍历提取列表里面的元素for i in result:# 字符串分割返回列表index i.split(|)# 通过列表索引位置取值num index[3] # 车次star_time index[8] # 出发时间arrive_time index[9] # 到达时间use_time index[10] # 耗时special_class index[32] # 特等座frist_class index[31] # 一等座second_class index[30] # 二等座hard_sleeper index[28] # 硬卧hard_seat index[29] # 硬座no_seat index[26] # 无座soft_sleeper index[23]# 软卧dict {序号:page,车次:num,出发时间:star_time,到达时间:arrive_time,耗时:use_time,特等座:special_class,一等座:frist_class,二等座:second_class,软卧:soft_sleeper,硬卧:hard_sleeper,硬座:hard_seat,无座: no_seat}tb.add_row([page, #序号索引num, # 车次star_time,# 出发时间arrive_time,# 到达时间use_time, # 耗时special_class, # 特等座frist_class, # 一等座second_class,# 二等座soft_sleeper, # 软卧hard_sleeper,# 硬卧hard_seat, # 硬座no_seat,# 无座])page 1print(tb)# def change_chinese(chinese): # 把中文自动转换为拼音 # text pinyin(chinese, styleStyle.NORMAL) # string .join(t[0] for t in text) # return stringdef selenium_login():# 0.配置谷歌浏览器加载项options webdriver.ChromeOptions()options.add_argument(f--user-data-dir{user_data_dir}) # 添加浏览器数剧# 1.将加载项配置到启动浏览器中 打开/创建浏览器对象driver webdriver.Chrome(executable_pathrD:\game\chromedriver.exe, optionsoptions)# 2.输入网址driver.get(https://kyfw.12306.cn/otn/view/index.html)# 3.输入账号 -- 找到账号的输入框 selenium 通过元素面板去定位元素driver.find_element(bycss selector, value#J-userName).send_keys(login[account])# 4.输入密码 -- 找到密码的输入框driver.find_element(bycss selector, value#J-password).send_keys(login[password])# 5.点击登录按钮driver.find_element(bycss selector, value#J-login).click()time.sleep(0.5)# 6.输入身份证后4位driver.find_element(bycss selector, value#id_card).send_keys(login[id_card])# 7.点击获取验证码driver.find_element(bycss selector, value#verification_code).click()# 8.输入验证码code input(请输入验证码)driver.find_element(bycss selector, value#code).send_keys(code)driver.find_element(bycss selector, value#verification_code).click()# 9.点击确认按钮driver.find_element(bycss selector, value#sureClick).click()# 有时候报错是需要延时等待 用 driver.implicitly_wait(10)代码 可以实现加载完就就进行下一步# 而time.sleep(5)则必须等我规定的时间driver.implicitly_wait(5)# 10点击车票预定按钮driver.find_element(bycss selector, value#link_for_ticket).click()# 11.1 选择出发的城市--点击那个框driver.find_element(bycss selector, value#fromStationText).click()# 11.2 选择出发的城市--选择城市driver.find_element(bycss selector, value#fromStationText).send_keys(from_city)# 11.3 选择出发的城市--回车确定driver.find_element(bycss selector, value#fromStationText).send_keys(Keys.ENTER)# 12.1 选择目的的城市--点击那个框driver.find_element(bycss selector, value#toStationText).click()# 12.2 选择目的的城市--选择城市driver.find_element(bycss selector, value#toStationText).send_keys(to_city)# 12.3 选择目的的城市--回车确定driver.find_element(bycss selector, value#toStationText).send_keys(Keys.ENTER)# 13.1 选择出发的日期--点击那个框driver.find_element(bycss selector, value#train_date).clear()# 12.2 选择出发的日期--选择城市driver.find_element(bycss selector, value#train_date).send_keys(train_date)# 12.3 选择出发的日期--回车确定driver.find_element(bycss selector, value#train_date).send_keys(Keys.ENTER)# # 12.4 点击--显示全部可预订的车次# driver.find_element(bycss selector, valueavail_ticket).click()# 12.5 点击查询driver.implicitly_wait(5)driver.find_element(bycss selector, value#query_ticket).click()num int(input(请输入您想要的车次:))# 点击预订按钮 -- 选择要预定的是第几躺车 -- 这个代码没有问题# driver.find_element(bycss selector, value#ticket_65000G279007_01_03 td.no-br).click()# //div//tbody[idqueryLeftTable]/tr[contains(id,ticket)]/id -- 但是selenium的find_elements不可以用id找到元素。ticket_list driver.find_elements(byxpath, value//div//tbody[idqueryLeftTable]/tr[contains(id,ticket)])ticket_num ticket_list[num].get_attribute(id)ticket_pre ticket_num td.no-br# 12.6 点击想要车次的预定按钮driver.find_element(bycss selector, valuef#{ticket_pre}).click()# 13.1 勾选想要的乘车人driver.find_element(bycss selector, value#normalPassenger_0).click()# 13.2 提交订单driver.find_element(bycss selector, value#submitOrder_id).click()driver.implicitly_wait(5)# 13.3 选择靠窗的1F的位置# driver.find_element(bycss selector, value#1F).click() --这种行不通只能下方这种driver.find_element(bycss selector, value#erdeng1 ul:nth-child(4) li:nth-child(2)).click()# 13.4 再次确认提交time.sleep(2)driver.find_element(bycss selector, value#qr_submit_id).click()# driver.find_element(bycss selector, value#qr_submit_id).click()# # 14. 网上支付 -- payButton# driver.find_element(bycss selector, value#payButton).click()# # 15. 取消订单 -- cancelButton# driver.find_element(bycss selector, value#cancelButton).click()f open(login.json, encodingutf-8).read() login json.loads(f)if __name__ __main__:print_ticketlist()selenium_login()三、进阶–展望 1.首先可以将自动化操作用try–except这样不会一直报错更为规范。 2.免登录因为登录其实要验证码这样抢票也不方便。于是我就又继续学习了一些发现了两种方法一是可以保存浏览器的数据因为selenium每次打开的是一个新的程序但是我们可以通过设置参数让他打开是有记忆的但是没有用。第二种是cookie,是没有什么问题的目前已经实现接下尝试各种方法的cookie看行不行。后续我会发此程序。 3.多线程多进程主要我已经实现cookie免登录我想着是否可以打开多个页面然后多个账号一起抢他们所需要的票呢。 总结 1.最开始跟着写这个程序只会照着抄然后根本不懂后面就是差了一点点成功也不会找错误。 2.后面学习了一下爬虫更明白一点语法以及自己也更会如何定位元素了。还有就是request的一个请求这些代码也更看得懂了 3.想着结合多线程然后实现批量抢票同时也希望代价的容错率高也就是说在自动化不用点几下程序就不行了让它可以有更好的性能。-- 未来学习的一个点。加油
http://www.dnsts.com.cn/news/225830.html

相关文章:

  • 制作小网站用asp做网站大概多久
  • 漳州专业网站建设公司简述网站推广的方法
  • 小米商城网站设计论文wordpress 菜单 跳转
  • 北京网站开发公司前十名3d效果图制作教程
  • 哪有可以专门做外包项目的网站嘉兴网站建设有前途吗
  • 宝山网站建设服务北京手机网站设计电话
  • 电商网站开发的目的和意义珠海网站制作套餐
  • 网上做网站钱被骗了报案有用吗创造力网站设计
  • 启东建设网站什么叫响应式网页
  • 主要网站 开发语言WordPress为什么进不去
  • 郑州网站建设喝彩科技临夏州建设局网站
  • 寻找外贸客户的网站wordpress负载均衡
  • 国家和城乡建设部网站云南微网站开发
  • 湘潭网站建设选择磐石网络烟台网站搜索优化
  • 网站建设与运营就业高端娱乐网站建设
  • 做网站的实验报告提供秦皇岛网站建设哪家好
  • 分类信息网站系统cms建设网站的公司汇总
  • 电子商务网站开发主要有哪些网站制作资料收集
  • 局域网如何做视频网站微商分销平台有哪些
  • 做企业邮箱的网站王占军
  • 网站页面构架汕头网络推广seo方案
  • 自主建站网站平台做创意ppt网站
  • 两学一做考试网站wordpress章节分页
  • 网站建站建设费用梧州网站推广设计
  • 南京建站公司网站微信引流推广平台
  • 做游戏试玩网站长治网站制作一般需要多少钱
  • 手机网站头部百中搜网站建设
  • 农村建设房子建设网站建设食品网站开发步骤
  • 定制网站建设服务平台wordpress分销系统
  • 汕头有没有做网站pc网站案例