Python实现12306网站的余票查询

火车站名对应的编号可以先在网上下载这个字典
https://pan.baidu.com/s/1hLb3DLB6uC6ADtXKALPBZA
可以这里下载的,整理好的py文件,可以直接使用.
Code:

coding: utf-8

“”"命令行火车票查看器
Usage:
tickets [-gdtkz]

Options:
-h,–help 显示帮助菜单
-g 高铁
-d 动车
-t 特快
-k 快速
-z 直达

Example:
tickets 北京 上海 2016-10-10
tickets -dg 成都 南京 2016-10-10

from docopt import docopt
from prettytable import PrettyTable
from colorama import Fore
import requests, stationsInfo, warnings


def cli():
    arguments = docopt(__doc__, version='ticket 1.0')
    from_station = stationsInfo.stations2CODE[arguments.get('<from>')]
    to_station = stationsInfo.stations2CODE[arguments.get('<to>')]
    date = arguments.get('<date>')
    # 列表推导式,得到的是查询车次类型的集合
    options = ''.join([key for key, value in arguments.items() if value is True])
    print(options)

    url = ('https://kyfw.12306.cn/otn/leftTicket/query?'
           'leftTicketDTO.train_date={}&'
           'leftTicketDTO.from_station={}&'
           'leftTicketDTO.to_station={}&'
           'purpose_codes=ADULT').format(date, from_station, to_station)

    warnings.filterwarnings("ignore")  # 这个网站是有安全警告的,这段代码可以忽略警告
    r = requests.get(url, verify=False)
    # print(r.json())
    # requests得到的是一个json格式的对象,r.json()转化成python字典格式数据来提取,所有的车次结果result
    raw_trains = r.json()['data']['result']
    pt = PrettyTable()
    pt._set_field_names("车次 车站 时间 经历时 商务座 一等座 二等座 高级软卧 软卧 动卧 硬卧 软座 硬座 无座".split())
    for raw_train in raw_trains:
        # split切割之后得到的是一个列表
        data_list = raw_train.split("|")
        train_no = data_list[3]
        initial = train_no[0].lower()
        # print(train_no[0])
        # 判断是否是查询特定车次的信息
        if not options or initial in options:
            from_station_code = data_list[6]
            to_station_code = data_list[7]
            from_station_name = ''
            to_station_name = ''
            start_time = data_list[8]
            arrive_time = data_list[9]
            time_duration = data_list[10]
            business_seat = data_list[32] or "--"
            first_class_seat = data_list[31] or "--"
            second_class_seat = data_list[30] or "--"
            high_soft_sleep = data_list[21] or "--"
            soft_sleep = data_list[23] or "--"
            move_sleep = data_list[33] or "--"
            hard_sleep = data_list[28] or "--"
            soft_seat = data_list[24] or "--"
            hard_seat = data_list[29] or "--"
            no_seat = data_list[26] or "--"

        pt.add_row([
            # 对特定文字添加颜色
            train_no,
            '\n'.join([Fore.GREEN + stationsInfo.stations2CN[from_station_code] + Fore.RESET,
                       Fore.RED + stationsInfo.stations2CN[to_station_code] + Fore.RESET]),
            '\n'.join([Fore.GREEN + start_time + Fore.RESET, Fore.RED + arrive_time + Fore.RESET]),
            time_duration,
            business_seat,
            first_class_seat,
            second_class_seat,
            high_soft_sleep,
            soft_sleep,
            move_sleep,
            hard_sleep,
            soft_seat,
            hard_seat,
            no_seat
        ])

    print(pt)


if __name__ == '__main__':
    cli()

实现效果

在这里插入图片描述

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
【为什么学爬虫?】        1、爬虫入手容易,但是深入较难,如何写出高效率的爬虫,如何写出灵活性高可扩展的爬虫都是一项技术活。另外在爬虫过程中,经常容易遇到被反爬虫,比如字体反爬、IP识别、验证码等,如何层层攻克难点拿到想要的数据,这门课程,你都能学到!        2、如果是作为一个其他行业的开发者,比如app开发,web开发,学习爬虫能让你加强对技术的认知,能够开发出更加安全的软件和网站 【课程设计】 一个完整的爬虫程序,无论大小,总体来说可以分成三个步骤,分别是:网络请求:模拟浏览器的行为从网上抓取数据。数据解析:将请求下来的数据进行过滤,提取我们想要的数据。数据存储:将提取到的数据存储到硬盘或者内存中。比如用mysql数据库或者redis等。那么本课程也是按照这几个步骤循序渐进的进行讲解,带领学生完整的掌握每个步骤的技术。另外,因为爬虫的多样性,在爬取的过程中可能会发生被反爬、效率低下等。因此我们又增加了两个章节用来提高爬虫程序的灵活性,分别是:爬虫进阶:包括IP代理,多线程爬虫,图形验证码识别、JS加密解密、动态网页爬虫、字体反爬识别等。Scrapy和分布式爬虫:Scrapy框架、Scrapy-redis组件、分布式爬虫等。通过爬虫进阶的知识点我们能应付大量的反爬网站,而Scrapy框架作为一个专业的爬虫框架,使用他可以快速提高我们编写爬虫程序的效率和速度。另外如果一台机器不能满足你的需求,我们可以用分布式爬虫让多台机器帮助你快速爬取数据。 从基础爬虫到商业化应用爬虫,本套课程满足您的所有需求!【课程服务】 专属付费社群+定期答疑

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值