12306+python教程_潭州python 12306案例vip特训班视频教程 - CSDN
  • 基础差可以根据教程手把手教你实现12306登录用户、余票查询、下单等功能。本代码基于Python2.7 实现12306抢票,我的代码与视频有些不同,希望有助于你的学习。有问题请私信,共同学习,共同进步!
  • python12306抢票教程

    2019-01-10 16:45:02
    非常感谢原作者 如果有一点代码基础 基本看文档就可以跑通 源代码直通车https://github.com/testerSunshine/12306 这里给一些初次使用python的同学一个教程 有遇到问题 可以留言 我会贴出解决方案 首先 写代码的...

    最近有个开源项目很火,使用python代码自动抢票。笔者下载下来,跑了下,确实很实用以后再也不用买加速包了。  哈哈哈哈

    非常感谢原作者 如果有一点代码基础 基本看文档就可以跑通  源代码直通车https://github.com/testerSunshine/12306 这里给一些初次使用python的同学一个教程 有遇到问题 可以留言 我会贴出解决方案

    首先 写代码的作者使用的是python2.7.10-2.7.15版本的python 

    如果你是没用过python的用户,电脑没有下载过python的。可以直接下载python2.7.10

    如果你是一位python程序员或其他,已经下载了最新的python3.7版本也没关系,稍微复杂点,稍后讲。

    进入python官网https://www.python.org/downloads/ 下载对应版本

    下载完成后 对安装包傻瓜式安装即可 记住下载的路径就行。

    配置环境

    电脑--属性--高级系统设置--高级--环境变量 --Path

    在Path中增加2个路径 一个是安装根目录 一个是Script目录  我的路径为C:\Python27 和C:\Python27\Scripts

    在cmd中输入python -V   查看python版本 显示了python 2.7.10 成功

    下载抢票源代码 https://github.com/testerSunshine/12306  

    里面有个文件 requirements.txt 是代码需要安装的库

    在cmd中 先cd入requirements.txt的路径  输入pip install -i https://pypi.tuna.tsinghua.edu.cn/simple -r requirements.txt

    利用pip自动安装所需的库

    注册若快打码器  若快注册地址:http://www.ruokuai.com/client/index?6726  这个工具是用来自动识别登录的验证码  提示下这里充值一元钱 可以用很久 不需要充太多钱

    在config文件夹中ticket_config.yaml  用word或编辑器打开 更改yaml文件中的信息  这个文件是你的抢票信息的配置文件 按照注释更改信息 有账号名密码,出发站,班次等等

    更改完 管理员权限打开cmd 输入python run.py

    ----------------------------------------------------------------------------------------------------------

    之前有说已有高版本python3.x的 需要重新下载python2.7.10版本

    windows可以同时存在2个版本 这里有篇博客 可以解决https://blog.csdn.net/qq_27089287/article/details/79114441

    安装完成之后 cmd输入python2 run.py

    -----------------------------------------------------------------------------------------------------------

    这里贴一些 错误提示 和解决方案

    安装requirements.txt 中的库时报错

    解决方法:利用cd命令 进入到requirements.txt的文件夹中 再输入命令 

     

      

    展开全文
  • 本章讲,简介和普及,找资料,过程 !!! 写这个的原因,年年需要抢票,年年抢不到 !!! ...市面上的抢票软件多的很。...大企业,网易,360,百度,等等,抢票...为免不是最好的方案,决定用Python,但怎么搞。 pyth...

    本章讲,简介和普及,找资料,过程 !!!

    写这个的原因,年年需要抢票,年年抢不到  !!!

     

    市面上的抢票软件多的很。老套路,开始肯定是思考。

    大企业,网易,360,百度,等等,抢票是基于,前端的脚本方式进行。

    我做后端,果断放弃此技术路线。

     

    软件路线,市面软件用的技术方案:.NET,插件。如:分流抢票软件,等。

    为免不是最好的方案,决定用Python,但怎么搞。

    python我此时可是零基础,还是百度下基础,突然间眼前一亮。12306抢票软件源码详解!

    从那里,我发现了一系列文件,在边学,边操的模式下,就开干了。后续写一系列文章。

     

    一口气看完他的所有过程。在看完他的教程后,自己也开始动手。顺便就写得此文总结。

    首先,讲讲看他的文章的几点不足之处,写作新手。

    1.看完此系列的文章而思考。首先,作者应该是一个学生,或者,在自学python的人。

             python开发环境用的centos,为何不用ubuntu呢!市面上做python开发的,绝B是用vmware+ubuntu的环境。

    2.文章是真的零基础开干,却缺乏总结和遗漏的说明。

            特别是细节之处的说明和总结,没细说道来。文章的大纲和逻辑也没有。

    3.其中还有些差错,且代码,妈的,都是图片,不是我喷。

             分享出来就应该用代码啊,且不管是不是照着录入,都不容易。

    4.我在vmware+ubuntu下,实现的文章中同样的事,同样的抢票功能,且修改其中部分错误,和补充部分注解。

        后续看我写系列文章。让你知其然,知其所以然。下面是我参考学习的几篇文章,也是我上面说的文章。

     

    参考学习的链接: https://blog.csdn.net/qq_26870933
    1.使用VMware Workstation 14 Pro安装 CentOS 7

    2.在centos7中配置python3虚拟环境并安装Scrapy框架

    3.在Python3虚拟环境中安装selenium+chrome

      补充学习,链接: Selenium补充学习 

      补充学习,链接: selenium之 chromedriver与chrome版本映射表(更新至v2.43)

    4.在centos7中安装pycharm(补充)

    5.12306抢票软件源码详解

    6.12306换乘抢票

     

    扫码关注微信,不定期用心推送优质文章。

    展开全文
  • 个人的力量是有限的,团队合作是无限的。希望有一个自己开源的,有几个贡献...[已关闭] 简单、高效的12306.com(全能出行、非 12306.cn 中国铁路客户服务中心)抢火车票项目。4种抢票模式。车次时间限制。无需内嵌浏览...

    个人的力量是有限的,团队合作是无限的。希望有一个自己开源的,有几个贡献者。

    java  YeautyYE/train-ticket-reaper

    https://github.com/YeautyYE/train-ticket-reaper

    [已关闭] 简单、高效的12306.com(全能出行、非 12306.cn 中国铁路客户服务中心)抢火车票项目。4种抢票模式。车次时间限制。无需内嵌浏览器,纯HTTP请求。

     

    python testerSunshine/12306

    https://github.com/testerSunshine/12306

    12306智能刷票,订票

     

    java  hao707789/12306

    https://github.com/hao707789/12306

    https://blog.csdn.net/qq_21181253/article/details/73017306

    原本是私人项目,但作者时间有限无法继续更新,因此交给广大coding伙计们。16年该项目可以实现登录、查票、刷票、查询订单、退订等功能。其中部分控件被我重写或修改。有些地方试试双击,比如席别那里,选择后想删除只要双击该席别就行。17年发现查票和提交订单功能无法使用,修复了查票功能,目前提交订单功能需要重写。 如果有大牛,请重构下该代码,实现界面、事件、逻辑分离。可以看到目前打开界面速度比较慢,因为有很多是请求了再加载。分离了界面就会非常快的展示出来,体验也会更好。 另外配置文件内置了我的12306账号,如果需要测试,请成功登录一次你的账号并选择记住密码,再不清空编译后目录时,成功登录的账号将会在被记住。

     

    展开全文
  • Python实现12306购票程序 项目Github地址:https://github.com/Henryhaohao/12306_Ticket/ 12306官网 - https://kyfw.12306.cn/otn/leftTicket/init Author

    Python实现12306购票程序 在这里插入图片描述


    项目Github地址:https://github.com/Henryhaohao/12306_Ticket/

    12306官网 - https://kyfw.12306.cn/otn/leftTicket/init

    Author ?Henryhaohao?
    Email 1073064953@qq.com

    ?免责声明

    软件均仅用于学习交流,请勿用于任何商业用途!感谢大家!


    ?介绍

    ? 2018-11-03 | 12306界面大改版!大家不用担心,换汤不换药,有几处地方我已修改并同步到最新,亲测可用!☑️

    该项目为12306购票的命令行形式。目前实现的功能有:

    • 余票查询 (Query_Ticket)
    • 购票 (Order_Ticket)
    • 取消订单 (Cancel_Order)
    • 退票 (Refund_Ticket)

    ?运行环境

    Version: Python3


    ?安装依赖库

    pip3 install -r requirements.txt
    

    ?目前版本


    ?运行截图

    • 订单截图
      在这里插入图片描述
    • 订票 (Order_Ticket)
      在这里插入图片描述
    • 取消订单 (Cancel_Order)
      在这里插入图片描述
    • 退票 (Refund_Ticket)
      在这里插入图片描述

    ?总结

    最后,如果你觉得这个项目不错或者对你有帮助,给个Star呗,也算是对我学习路上的一种鼓励!

    哈哈哈,感谢大家!笔芯哟~**??

    展开全文
  • 今天就和大家一起来讨论一下python实现12306余票查询(pycharm+python3.7),一起来感受一下python爬虫的简单实践我们说先在浏览器中打开开发者工具(F12),尝试一次余票的查询,通过开发者工具查看发出请求的包 ...

    今天就和大家一起来讨论一下python实现12306余票查询(pycharm+python3.7),一起来感受一下python爬虫的简单实践
    我们说先在浏览器中打开开发者工具(F12),尝试一次余票的查询,通过开发者工具查看发出请求的包

    Python爬虫:12306抢票,开源代码!

    可以看到红框框中的URL就是我们向12306服务器发出的请求,那么具体是什么呢?我们来看看
    https://kyfw.12306.cn/otn/leftTicket/queryZ?leftTicketDTO.train_date=2019-01-21&leftTicketDTO.from_station=CDW&leftTicketDTO.to_station=SZQ&purpose_codes=ADULT
    可以看到发出请求的几个字段:

    leftTicketDTO.train_date:查询的日期
    leftTicketDTO.from_station:查询的出发地
    leftTicketDTO.to_station:查询的目的地
    purpose_codes:不太清楚这个字段是用来做什么的,就默认吧

    可以从我们递交的URL请求看出,我们输入的成都,深圳都变成了对应的编号,比如,成都(CDW)、深圳(SZQ),所以当我们程序进行输入的时候要进行一下处理,12306的一个地方存储着这些城市名与编码对应的文档:https://kyfw.12306.cn/otn/resources/js/framework/station_name.js?station_version=1.8971

    如果你依然在编程的世界里迷茫,可以加入我们的Python学习扣qun:784758214,看看前辈们是如何学习的。交流经验。从基础的python脚本到web开发、爬虫、django、数据挖掘等,零基础到项目实战的资料都有整理。送给每一位python的小伙伴!分享一些学习的方法和需要注意的小细节,点击加入我们的 python学习者聚集地

    i

    下面我们就编写一个小程序,将这些城市名与编号提取出来:

    import re,requests
    
    url = "https://kyfw.12306.cn/otn/resources/js/framework/station_name.js?station_version=1.8971"
    response = requests.get(url,verify=False)
    #将车站的名字和编码进行提取
    chezhan = re.findall(r'([\u4e00-\u9fa5]+)\|([A-Z]+)', response.text)
    chezhan_code = dict(chezhan)
    #进行交换
    chezhan_names = dict(zip(chezhan_code.values(),chezhan_code.keys()))
    #打印出得到的车站字典
    print(chezhan_names)
    

    得到的打印结果如下(只截取部分显示):

    {'VAP': '北京北', 'BOP': '北京东', 'BJP': '北京', 'VNP': '北京南', 'BXP': '北京西', 'IZQ': '广州南', 'CUW': '重庆北', 'CQW': '重庆', 'CRW': '重庆南', 'CXW': '重庆西', 'GGQ': '广州东', 'SHH': '上海', 'SNH': '上海南', 'AOH': '上海虹桥', 'SXH': '上海西', 'TBP': '天津北', 'TJP': '天津', 'TIP': '天津南', 'TXP': '天津西', 'XJA': '香港西九龙', 'CCT': '长春', 'CET': '长春南', 'CRT': '长春西', 'ICW': '成都东', 'CNW': '成都南', 'CDW': '成都', 'CSQ': '长沙', 'CWQ': '长沙南',}

    接下来我们就动手开始程序的主要代码编写:

    在学习过程中有什么不懂得可以加我的
    python学习交流扣扣qun,784758214
    群里有不错的学习视频教程、开发工具与电子书籍。
    与你分享python企业当下人才需求及怎么从零基础学习好python,和学习什么内容
    def main():
        date         = input("请输入时间(如2019-01-22):\n")
        from_station = chezhan_code[input("请输入起始站点:\n")]
        to_station   = chezhan_code[input("请输入目的站点:\n")]
        url          = "https://kyfw.12306.cn/otn/leftTicket/queryZ?"
        headers = {
            "User-Agent": "Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/63.0.3239.26 Safari/537.36 Core/1.63.5702.400 QQBrowser/10.2.1893.400"
        }
        url=url+"leftTicketDTO.train_date="+date+"&leftTicketDTO.from_station="+from_station+"&leftTicketDTO.to_station="+to_station+"&purpose_codes=ADULT"
        #print(url) 已经检查过生成的URL是正确的
        #request请求获取主页
        r = requests.get(url,headers=headers)
        r.raise_for_status()   #如果发送了一个错误的请求,会抛出异常
        r.encoding = r.apparent_encoding
        showTicket(r.text)
    

    用户输入时间、起始站点、目的站点,然后通过get来请求,然后我们对返回的网页信息进行解析。我们现将上面代码的r.text进行打印,看看我们请求之后,返回了什么样的信息,然后决定我们应该如何解析

    Python爬虫:12306抢票,开源代码!

    这样看着不方便,我们粘贴到记事本中,进行详细的分析:

    image

    可以与12306显示的信息进行对比,K829是车次,CDW与BJQ是出发地和目的地,10:10是出发时间,06:13是到达时间,44:21是历时时间,20190123为查询的日期,剩下的就是一系列票的各种信息。
    下面就是对这些返回的信息进行解析,其实这也是python爬虫的关键,就是解析!!!

    我们先把信息转化为json格式,可以看到都是用“|”隔开的,那么我们就用split函数分割出来,下面是主要功能代码:

    def showTicket(html):
        html = json.loads(html)
        table = PrettyTable(["  车次  ","出发车站","到达车站","出发时间","到达时间"," 历时 ","商务座"," 一等座","二等座","高级软卧","软卧","动卧","硬卧","软座","硬座","无座","其他","备注"])
        for i in html['data']['result']:
            name = [
                        "station_train_code",
                        "from_station_name",
                        "to_station_name",
                        "start_time",
                        "arrive_time",
                        "lishi",
                        "swz_num",
                        "zy_num",
                        "ze_num",
                        "dw_num",
                        "gr_num",
                        "rw_num",
                        "yw_num",
                        "rz_num",
                        "yz_num",
                        "wz_num",
                        "qt_num",
                        "note_num"
                   ]
    
            data = {
                        "station_train_code": '',
                        "from_station_name": '',
                        "to_station_name": '',
                        "start_time": '',
                        "arrive_time": '',
                        "lishi": '',
                        "swz_num": '',
                        "zy_num": '',
                        "ze_num": '',
                        "dw_num": '',
                        "gr_num": '',
                        "rw_num": '',
                        "yw_num": '',
                        "rz_num": '',
                        "yz_num": '',
                        "wz_num": '',
                        "qt_num": '',
                        "note_num": ''
                    }
            #将各项信息提取并赋值
            item = i.split('|')                                 #使用“|”进行分割
            data["station_train_code"]  = item[3]               #获取车次信息,在3号位置
            data["from_station_name"]   = item[6]               #始发站信息在6号位置
            data["to_station_name"]     = item[7]               #终点站信息在7号位置
            data["start_time"]          = item[8]               #出发时间在8号位置
            data["arrive_time"]         = item[9]               #抵达时间在9号位置
            data["lishi"]               = item[10]              #经历时间在10号位置
            data["swz_num"]             = item[32] or item[25]  #特别注意,商务座在32或25位置
            data["zy_num"]              = item[31]              #一等座信息在31号位置
            data["ze_num"]              = item[30]              #二等座信息在30号位置
            data["gr_num"]              = item[21]              #高级软卧信息在21号位置
            data["rw_num"]              = item[23]              #软卧信息在23号位置
            data["dw_num"]              = item[27]              #动卧信息在27号位置
            data["yw_num"]              = item[28]              #硬卧信息在28号位置
            data["rz_num"]              = item[24]              #软座信息在24号位置
            data["yz_num"]              = item[29]              #硬座信息在29号位置
            data["wz_num"]              = item[26]              #无座信息在26号位置
            data["qt_num"]              = item[22]              #其他信息在22号位置
            data["note_num"]            = item[1]               #备注信息在1号位置
    
            color = Colored()
            data["note_num"] = color.white(item[1])
            #如果没有信息,那么就用“-”代替
            for pos in name:
                if data[pos] == "":
                    data[pos] = "-"
    
            tickets = []
            cont = []
            cont.append(data)
            for x in cont:
                tmp = []
                for y in name:
                    if y == "from_station_name":
                        s = color.green(chezhan_names[data["from_station_name"]])
                        tmp.append(s)
                    elif y == "to_station_name":
                        s = color.red(chezhan_names[data["to_station_name"]])
                        tmp.append(s)
                    elif y == "start_time":
                        s = color.green(data["start_time"])
                        tmp.append(s)
                    elif y == "arrive_time":
                        s = color.red(data["arrive_time"])
                        tmp.append(s)
                    elif y == "station_train_code":
                        s = color.yellow(data["station_train_code"])
                        tmp.append(s)
                    else:
                        tmp.append(data[y])
                tickets.append(tmp)
            for ticket in tickets:
                table.add_row(ticket)
        print(table)
    

    那么我们程序就成功啦!!!

    Python爬虫:12306抢票,开源代码!

    但是在编译器里面Prettytable的格子没有对齐,不要担心,我们到终端运行一下脚本,就可以看到很好看的输出啦:

    Python爬虫:12306抢票,开源代码!

    Python爬虫:12306抢票,开源代码!

    完成!!!下面是完整代码

    main.py

    # -*- coding: utf-8 -*-
    import re,requests,datetime,time,json
    from prettytable import PrettyTable
    from colorama import init,Fore
    from stationinfo import chezhan_code,chezhan_names
    
    init(autoreset=False)
    
    class Colored(object):
        def yeah(self,s):
            return Fore.LIGHTCYAN_EX + s + Fore.RESET
        def green(self,s):
            return Fore.LIGHTGREEN_EX + s + Fore.RESET
        def yellow(self,s):
            return Fore.LIGHTYELLOW_EX + s + Fore.RESET
        def white(self,s):
            return Fore.LIGHTWHITE_EX + s + Fore.RESET
        def blue(self,s):
            return Fore.LIGHTBLUE_EX + s + Fore.RESET
    
    def showTicket(html):
        html = json.loads(html)
        table = PrettyTable(["  车次  ","出发车站","到达车站","出发时间","到达时间"," 历时 ","商务座"," 一等座","二等座","高级软卧","软卧","动卧","硬卧","软座","硬座","无座","其他","备注"])
        for i in html['data']['result']:
            name = [
                        "station_train_code",
                        "from_station_name",
                        "to_station_name",
                        "start_time",
                        "arrive_time",
                        "lishi",
                        "swz_num",
                        "zy_num",
                        "ze_num",
                        "dw_num",
                        "gr_num",
                        "rw_num",
                        "yw_num",
                        "rz_num",
                        "yz_num",
                        "wz_num",
                        "qt_num",
                        "note_num"
                   ]
    
            data = {
                        "station_train_code": '',
                        "from_station_name": '',
                        "to_station_name": '',
                        "start_time": '',
                        "arrive_time": '',
                        "lishi": '',
                        "swz_num": '',
                        "zy_num": '',
                        "ze_num": '',
                        "dw_num": '',
                        "gr_num": '',
                        "rw_num": '',
                        "yw_num": '',
                        "rz_num": '',
                        "yz_num": '',
                        "wz_num": '',
                        "qt_num": '',
                        "note_num": ''
                    }
            #将各项信息提取并赋值
            item = i.split('|')                                 #使用“|”进行分割
            data["station_train_code"]  = item[3]               #获取车次信息,在3号位置
            data["from_station_name"]   = item[6]               #始发站信息在6号位置
            data["to_station_name"]     = item[7]               #终点站信息在7号位置
            data["start_time"]          = item[8]               #出发时间在8号位置
            data["arrive_time"]         = item[9]               #抵达时间在9号位置
            data["lishi"]               = item[10]              #经历时间在10号位置
            data["swz_num"]             = item[32] or item[25]  #特别注意,商务座在32或25位置
            data["zy_num"]              = item[31]              #一等座信息在31号位置
            data["ze_num"]              = item[30]              #二等座信息在30号位置
            data["gr_num"]              = item[21]              #高级软卧信息在21号位置
            data["rw_num"]              = item[23]              #软卧信息在23号位置
            data["dw_num"]              = item[27]              #动卧信息在27号位置
            data["yw_num"]              = item[28]              #硬卧信息在28号位置
            data["rz_num"]              = item[24]              #软座信息在24号位置
            data["yz_num"]              = item[29]              #硬座信息在29号位置
            data["wz_num"]              = item[26]              #无座信息在26号位置
            data["qt_num"]              = item[22]              #其他信息在22号位置
            data["note_num"]            = item[1]               #备注信息在1号位置
    
            color = Colored()
            data["note_num"] = color.white(item[1])
            #如果没有信息,那么就用“-”代替
            for pos in name:
                if data[pos] == "":
                    data[pos] = "-"
    
            tickets = []
            cont = []
            cont.append(data)
            for x in cont:
                tmp = []
                for y in name:
                    if y == "from_station_name":
                        s = color.green(chezhan_names[data["from_station_name"]])
                        tmp.append(s)
                    elif y == "to_station_name":
                        s = color.yeah(chezhan_names[data["to_station_name"]])
                        tmp.append(s)
                    elif y == "start_time":
                        s = color.green(data["start_time"])
                        tmp.append(s)
                    elif y == "arrive_time":
                        s = color.yeah(data["arrive_time"])
                        tmp.append(s)
                    elif y == "station_train_code":
                        s = color.yellow(data["station_train_code"])
                        tmp.append(s)
                    else:
                        tmp.append(data[y])
                tickets.append(tmp)
            for ticket in tickets:
                table.add_row(ticket)
        print(table)
    
    def main():
        date         = input("请输入时间:\n")
        from_station = chezhan_code[input("请输入起始站点:\n")]
        to_station   = chezhan_code[input("请输入目的站点:\n")]
        url          = "https://kyfw.12306.cn/otn/leftTicket/queryZ?"
        headers = {
            "User-Agent": "Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/63.0.3239.26 Safari/537.36 Core/1.63.5702.400 QQBrowser/10.2.1893.400"
        }
        url=url+"leftTicketDTO.train_date="+date+"&leftTicketDTO.from_station="+from_station+"&leftTicketDTO.to_station="+to_station+"&purpose_codes=ADULT"
        #print(url) 已经检查过生成的URL是正确的
        #request请求获取主页
        r = requests.get(url,headers=headers)
        r.raise_for_status()   #如果发送了一个错误的请求,会抛出异常
        r.encoding = r.apparent_encoding
        showTicket(r.text)
        #print(r.text)
    
    main()
    

    stationinfo.py

    在学习过程中有什么不懂得可以加我的
    python学习交流扣扣qun,784758214
    群里有不错的学习视频教程、开发工具与电子书籍。
    与你分享python企业当下人才需求及怎么从零基础学习好python,和学习什么内容
    import re,requests
    
    url = "https://kyfw.12306.cn/otn/resources/js/framework/station_name.js?station_version=1.8971"
    response = requests.get(url,verify=False)
    #将车站的名字和编码进行提取
    chezhan = re.findall(r'([\u4e00-\u9fa5]+)\|([A-Z]+)', response.text)
    chezhan_code = dict(chezhan)
    
    chezhan_names = dict(zip(chezhan_code.values(),chezhan_code.keys()))
    #print(chezhan_names)
    
    展开全文
  • Python12306余票查询

    2018-10-05 21:26:53
    简单的Python学习,用Python完成一个12306余票查询~ Python12306余票查询 参考资料来自Python 实现火车票查询工具 需要用到的第三方库 requests,使用 Python 访问 HTTP 资源的必备库。 docopt,Python3 ...
  • Python基础之12306车票信息抓取案例 1.准备工作 (1)安装模块 本案例需要使用Python内置模块之外的docopt模块、requests模块、prettytable模块 安装方法:使用管理员身份打开控制台,使用指令 pip install ...
  • 代码展示: import urllib.request as request import http.cookiejar as cookiejar import re import os import smtplib from email.mime.text import MIMEText import time ... user =...
  • python爬取12306

    2019-04-20 21:56:53
    import urllib.request as r from prttytable import PrettyTable from colorama import init,Fore import json import requests init(autoreset=False)
  • 效果图 ... 博主littlebigluo已经训练好了CNN分类器,所以获取验证图像后直接requests.post图片到littlebigluo的服务器,通过CNN前传返回验证结果到浏览器。 不要频繁访问,服务器处理速度不够 ...
  • 登录代码 from selenium import webdriver class LoginTest(): def test_vaildLogin(self): baseURL=...driver=webdriver.Firefox() driver.maximize_window() driver.get(baseURL) email=dr...
  • 价值1680元的python12306抢票实战全套教学视频 教程目录:01-1103-第一节:爬虫入门之爬虫基础了解 01-爬虫入门之爬虫基础了解 02-1106-第二节:常用的爬虫模块及使用方法 2,常用的爬虫模块及使用方法 03-1108-...
  • 使用Python这样的简单编程语言,你可以使用少量编程技能就可以爬取复杂的网站。如果手机上显示代码错乱,请分享到QQ或者其他地方,用电脑查看!!!python能干的东西有很多,这里不再过多叙述,直接重点干货。在这里...
  • github大佬开源的项目《12306-master》 链接: ...但是最近github上出现了一个12306python抢票软件也是火的不只一点点。 这是2019-12-29这位文贤平的开源项...
  • python编写12306窗体抢票软件(一) 第一次写博客,拿写过的软件练个手~ 12306是学习爬虫的比较好的一个练手网站。本文带你重零开始编写一个python窗体,十分简单,小白进来看哈~这节只说怎么编写窗体界面,下节介绍...
  • 微信搜索公众号:学习python的正确姿势,id:...给大家说一下,我要开始学习 Python 了, Python 最近很火嘛(小样,别太膨胀),不过还好我是个程序员,只不过之前玩的不是 Python 语言,所以接下来我要 pic...
  • 百度网盘教程目录:01-1103-第一节:爬虫入门之爬虫基础了解01-爬虫入门之爬虫基础了解02-1106-第二节:常用的爬虫模块及使用方法2,常用的爬虫模块及使用方法03-1108-第三节:12306官网登录详解3,12306官网登录...
  • 鉴于好多人想学Python爬虫,缺没有简单易学的教程,我将在CSDN和大家分享Python爬虫的学习笔记,不定期更新 基础要求 Python 基础知识 Python 的基础知识,大家可以去菜鸟教程进行学习 菜鸟教程python基础 ...
1 2 3 4 5 ... 20
收藏数 789
精华内容 315
关键字:

12306+python教程