Python3(14)

如果你也是看准了Python,想自学Python,在这里为大家准备了丰厚的免费学习大礼包,带大家一起学习,给大家剖析Python兼职、就业行情前景的这些事儿。

一、Python所有方向的学习路线

Python所有方向路线就是把Python常用的技术点做整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。

二、学习软件

工欲善其必先利其器。学习Python常用的开发软件都在这里了,给大家节省了很多时间。

三、全套PDF电子书

书籍的好处就在于权威和体系健全,刚开始学习的时候你可以只看视频或者听某个人讲课,但等你学完之后,你觉得你掌握了,这时候建议还是得去看一下书籍,看权威技术书籍也是每个程序员必经之路。

四、入门学习视频

我们在看视频学习的时候,不能光动眼动脑不动手,比较科学的学习方法是在理解之后运用它们,这时候练手项目就很适合了。

四、实战案例

光学理论是没用的,要学会跟着一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。

五、面试资料

我们学习Python必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有阿里大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。

成为一个Python程序员专家或许需要花费数年时间,但是打下坚实的基础只要几周就可以,如果你按照我提供的学习路线以及资料有意识地去实践,你就有很大可能成功!
最后祝你好运!!!

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

def do_login(self):
“”“登录功能实现,手动识别验证码进行登录”“”
self.driver.visit(self.login_url)
sleep(1)
self.driver.fill(‘loginUserDTO.user_name’, self.user_name)
self.driver.fill(‘userDTO.password’, self.password)
print(‘请输入验证码……’)
while True:
if self.driver.url != self.init_my_url:
sleep(1)
else:
break


登录之后,就是控制刷票的各种操作处理了,这里,我就不贴代码了,因为代码比较多,别担心,在最后,我会贴出完整的代码的。


当刷票成功后,我会进行短信和邮件的双重通知,当然,这里短信通知的平台,就看你用那个具体来修改代码了,我用的是[互亿无线](https://bbs.csdn.net/topics/618317507)的体验版的免费短信通知接口;发送邮件模块我用的是smtplib,发送邮件服务器用的是163邮箱,如果用163邮箱的话,你还没有设置客户端授权密码,记得先设置客户端授权密码就好了,挺方便的。以下是主要实现代码:



def send_sms(self, mobile, sms_info):
“”“发送手机通知短信,用的是-互亿无线-的测试短信”“”
host = “106.ihuyi.com”
sms_send_uri = “/webservice/sms.php?method=Submit”
account = “C59782899”
pass_word = “19d4d9c0796532c7328e8b82e2812655”
params = parse.urlencode(
{‘account’: account, ‘password’: pass_word, ‘content’: sms_info, ‘mobile’: mobile, ‘format’: ‘json’}
)
headers = {“Content-type”: “application/x-www-form-urlencoded”, “Accept”: “text/plain”}
conn = httplib2.HTTPConnectionWithTimeout(host, port=80, timeout=30)
conn.request(“POST”, sms_send_uri, params, headers)
response = conn.getresponse()
response_str = response.read()
conn.close()
return response_str

def send_mail(self, receiver_address, content):
“”“发送邮件通知”“”
# 连接邮箱服务器信息
host = ‘smtp.163.com’
port = 25
sender = ‘xxxxxx@163.com’ # 你的发件邮箱号码
pwd = ‘******’ # 不是登陆密码,是客户端授权密码
# 发件信息
receiver = receiver_address
body = ‘

温馨提醒:

’ + content + ‘


msg = MIMEText(body, ‘html’, _charset=“utf-8”)
msg[‘subject’] = ‘抢票成功通知!’
msg[‘from’] = sender
msg[‘to’] = receiver
s = smtplib.SMTP(host, port)
# 开始登陆邮箱,并发送邮件
s.login(sender, pwd)
s.sendmail(sender, receiver, msg.as_string())

说了那么多,感觉都是说了好多废话啊,哈哈,不好意思,耽误大家时间来看我瞎扯了,我贴上大家最关心的源码,请接码,大家在尝试运行过程中,有任何问题,可以给点击[这行蓝色字体](https://bbs.csdn.net/topics/618317507),把问题截图下来,或着私信我,我看到都会及时回复大家的:



#!/usr/bin/env python

-- coding: utf-8 --

“”"
通过splinter刷12306火车票
进入登陆页面,可以选择扫码登陆或者账号密码登陆
登陆成功后,接下来的事情,交由脚本来做了,静静的等待抢票结果就好(刷票过程中,浏览器不可关闭)
抢票成功,会进行手机短信和邮件的通知
author: cuizy
time: 2018-11-21
“”"

import re
from splinter.browser import Browser
from time import sleep
import sys
import httplib2
from urllib import parse
import smtplib
from email.mime.text import MIMEText
import time

class BrushTicket(object):
“”“买票类及实现方法”“”

def __init__(self, passengers, from_time, from_station, to_station, number, seat_type, receiver_mobile,
             receiver_email):
    """定义实例属性,初始化"""
    # 乘客姓名
    self.passengers = passengers
    # 起始站和终点站
    self.from_station = from_station
    self.to_station = to_station
    # 乘车日期
    self.from_time = from_time
    # 车次编号
    self.number = number.capitalize()
    # 座位类型所在td位置
    if seat_type == '商务座特等座':
        seat_type_index = 1
        seat_type_value = 9
    elif seat_type == '一等座':
        seat_type_index = 2
        seat_type_value = 'M'
    elif seat_type == '二等座':
        seat_type_index = 3
        seat_type_value = 0
    elif seat_type == '高级软卧':
        seat_type_index = 4
        seat_type_value = 6
    elif seat_type == '软卧':
        seat_type_index = 5
        seat_type_value = 4
    elif seat_type == '动卧':
        seat_type_index = 6
        seat_type_value = 'F'
    elif seat_type == '硬卧':
        seat_type_index = 7
        seat_type_value = 3
    elif seat_type == '软座':
        seat_type_index = 8
        seat_type_value = 2
    elif seat_type == '硬座':
        seat_type_index = 9
        seat_type_value = 1
    elif seat_type == '无座':
        seat_type_index = 10
        seat_type_value = 1
    elif seat_type == '其他':
        seat_type_index = 11
        seat_type_value = 1
    else:
        seat_type_index = 7
        seat_type_value = 3
    self.seat_type_index = seat_type_index
    self.seat_type_value = seat_type_value
    # 通知信息
    self.receiver_mobile = receiver_mobile
    self.receiver_email = receiver_email
    # 新版12306官网主要页面网址
    self.login_url = 'https://kyfw.12306.cn/otn/resources/login.html'
    self.init_my_url = 'https://kyfw.12306.cn/otn/view/index.html'
    self.ticket_url = 'https://kyfw.12306.cn/otn/leftTicket/init?linktypeid=dc'
    # 浏览器驱动信息,驱动下载页:https://sites.google.com/a/chromium.org/chromedriver/downloads
    self.driver_name = 'chrome'
    self.driver = Browser(driver_name=self.driver_name)

def do_login(self):
    """登录功能实现,手动识别验证码进行登录"""
    self.driver.visit(self.login_url)
    sleep(1)
    # 选择登陆方式登陆
    print('请扫码登陆或者账号登陆……')
    while True:
        if self.driver.url != self.init_my_url:
            sleep(1)
        else:
            break

def start_brush(self):
    """买票功能实现"""
    # 浏览器窗口最大化
    self.driver.driver.maximize_window()
    # 登陆
    self.do_login()
    # 跳转到抢票页面
    self.driver.visit(self.ticket_url)
    try:
        print('开始刷票……')
        # 加载车票查询信息
        self.driver.cookies.add({"_jc_save_fromStation": self.from_station})
        self.driver.cookies.add({"_jc_save_toStation": self.to_station})
        self.driver.cookies.add({"_jc_save_fromDate": self.from_time})
        self.driver.reload()
        count = 0
        while self.driver.url == self.ticket_url:
            try:
                self.driver.find_by_text('查询').click()
            except Exception as error_info:
                print(error_info)
                sleep(1)
                continue
            sleep(0.5)
            count += 1
            local_date = time.strftime("%Y-%m-%d %H:%M:%S", time.localtime())
            print('第%d次点击查询……[%s]' % (count, local_date))
            try:
                current_tr = self.driver.find_by_xpath('//tr[@datatran="' + self.number + '"]/preceding-sibling::tr[1]')
                if current_tr:
                    if current_tr.find_by_tag('td')[self.seat_type_index].text == '--':
                        print('无此座位类型出售,已结束当前刷票,请重新开启!')
                        sys.exit(1)
                    elif current_tr.find_by_tag('td')[self.seat_type_index].text == '无':
                        print('无票,继续尝试……')
                        sleep(1)
                    else:
                        # 有票,尝试预订
                        print('刷到票了(余票数:' + str(current_tr.find_by_tag('td')[self.seat_type_index].text) + '),开始尝试预订……')
                        current_tr.find_by_css('td.no-br>a')[0].click()
                        sleep(1)
                        key_value = 1
                        for p in self.passengers:
                            if '()' in p:
                                p = p[:-1] + '学生' + p[-1:]
                            # 选择用户
                            print('开始选择用户……')
                            self.driver.find_by_text(p).last.click()
                            # 选择座位类型
                            print('开始选择席别……')
                            if self.seat_type_value != 0:
                                self.driver.find_by_xpath(
                                    "//select[@id='seatType_" + str(key_value) + "']/option[@value='" + str(
                                        self.seat_type_value) + "']").first.click()
                            key_value += 1
                            sleep(0.2)
                            if p[-1] == ')':
                                self.driver.find_by_id('dialog_xsertcj_ok').click()
                        print('正在提交订单……')
                        self.driver.find_by_id('submitOrder_id').click()
                        sleep(2)
                        # 查看放回结果是否正常
                        submit_false_info = self.driver.find_by_id('orderResultInfo_id')[0].text
                        if submit_false_info != '':
                            print(submit_false_info)
                            self.driver.find_by_id('qr_closeTranforDialog_id').click()
                            sleep(0.2)
                            self.driver.find_by_id('preStep_id').click()
                            sleep(0.3)
                            continue
                        print('正在确认订单……')
                        self.driver.find_by_id('qr_submit_id').click()
                        print('预订成功,请及时前往支付……')
                        # 发送通知信息
                        self.send_mail(self.receiver_email, '恭喜您,抢到票了,请及时前往12306支付订单!')
                        self.send_sms(self.receiver_mobile, '您的验证码是:8888。请不要把验证码泄露给其他人。')
                else:
                    print('不存在当前车次【%s】,已结束当前刷票,请重新开启!' % self.number)
                    sys.exit(1)
            except Exception as error_info:
                print(error_info)
                # 跳转到抢票页面
                self.driver.visit(self.ticket_url)
    except Exception as error_info:
        print(error_info)

def send_sms(self, mobile, sms_info):
    """发送手机通知短信,用的是-互亿无线-的测试短信"""
    host = "106.ihuyi.com"
    sms_send_uri = "/webservice/sms.php?method=Submit"
    account = "C59782899"
    pass_word = "19d4d9c0796532c7328e8b82e2812655"
    params = parse.urlencode(
        {'account': account, 'password': pass_word, 'content': sms_info, 'mobile': mobile, 'format': 'json'}
    )
    headers = {"Content-type": "application/x-www-form-urlencoded", "Accept": "text/plain"}
    conn = httplib2.HTTPConnectionWithTimeout(host, port=80, timeout=30)
    conn.request("POST", sms_send_uri, params, headers)
    response = conn.getresponse()
    response_str = response.read()
    conn.close()
    return response_str

def send_mail(self, receiver_address, content):
    """发送邮件通知"""
    # 连接邮箱服务器信息
    host = 'smtp.163.com'
    port = 25
    sender = 'gxcuizy@163.com'  # 你的发件邮箱号码
    pwd = '******'  # 不是登陆密码,是客户端授权密码
    # 发件信息
    receiver = receiver_address
    body = '<h2>温馨提醒:</h2><p>' + content + '</p>'
    msg = MIMEText(body, 'html', _charset="utf-8")
    msg['subject'] = '抢票成功通知!'
    msg['from'] = sender
    msg['to'] = receiver
    s = smtplib.SMTP(host, port)
    # 开始登陆邮箱,并发送邮件
    s.login(sender, pwd)
    s.sendmail(sender, receiver, msg.as_string())

if name == ‘main’:
# 乘客姓名
passengers_input = input(‘请输入乘车人姓名,多人用英文逗号“,”连接,(例如单人“张三”或者多人“张三,李四”,如果学生的话输入“王五()”):’)
passengers = passengers_input.split(“,”)
while passengers_input == ‘’ or len(passengers) > 4:
print(‘乘车人最少1位,最多4位!’)
passengers_input = input(‘请重新输入乘车人姓名,多人用英文逗号“,”连接,(例如单人“张三”或者多人“张三,李四”):’)
passengers = passengers_input.split(“,”)
# 乘车日期
from_time = input(‘请输入乘车日期(例如“2018-08-08”):’)
date_pattern = re.compile(r’^\d{4}-\d{2}-\d{2}$')
while from_time == ‘’ or re.findall(date_pattern, from_time) == []:
from_time = input(‘乘车日期不能为空或者时间格式不正确,请重新输入:’)
# 城市cookie字典

文末有福利领取哦~

👉一、Python所有方向的学习路线

Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。img

👉二、Python必备开发工具

img
👉三、Python视频合集

观看零基础学习视频,看视频学习是最快捷也是最有效果的方式,跟着视频中老师的思路,从基础到深入,还是很容易入门的。
img

👉 四、实战案例

光学理论是没用的,要学会跟着一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。(文末领读者福利)
img

👉五、Python练习题

检查学习结果。
img

👉六、面试资料

我们学习Python必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有阿里大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。
img

img

👉因篇幅有限,仅展示部分资料,这份完整版的Python全套学习资料已经上传

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 4
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值