用Python获取智慧校园每日课表并自动发送至邮箱

一、准备工作

1.1 观察登陆界面

我很很容易发现,当我们输入了账号与密码之后,就会出现这么一个链接,Response返回的是false:

http://sso.cqcet.edu.cn/verificationCode?userCode={username}

此处的username指的是你的智慧校园账号false表示登入时不需要输入验证码;当Response返回的是true时,需要输入验证码。

1.2 观察登陆请求过程

我们可以发现,Request URL为http://sso.cqcet.edu.cn/uaa/login_process

其携带的表单数据为:

1.3 观察访问课表的url请求

找到课表所在,点击它,你会发现其Request URL为http://ossc.cqcet.edu.cn/api/schedule/query。你可以在Preview发现课表信息。

但直接双击打开此链接会报如下错误:

原因:访问此链接需要携带请求负载

Date表示查询的具体某天的课表

二、代码实现

2.1 安装相应的依赖库

键盘按下Win+R调出如下界面:

输入cmd,进入如下界面:

输入pip install 库名,即可安装。

2.2 导入相应的依赖库

import json
import requests
import uuid # 用于获取验证码的,暂时可以不看
import yagmail # 用于发送邮件
import random
import datetime #用于获取
from fake_useragent import UserAgent # 用于获取随机的UserAgent

2.3 一些账号密码的写入

username = '********' # 账号
passwd = '*********' # 密码
now_time = datetime.datetime.now ().strftime('%Y-%m-%d') # 当天日期
contents = '' # 后面用于存储课表内容

# 随机生成uuid
uuid = uuid.uuid4()

# 随机UA
def get_random_ua():
    ua = UserAgent()
    return ua.random

2.4 url汇总及其他准备

# url汇总
code_url = f'http://sso.cqcet.edu.cn/validata/code/{uuid}'  # 验证码获取url
url = f'http://sso.cqcet.edu.cn/verificationCode?userCode={username}'  # 判断是否需要输入验证码url
login_url = 'http://sso.cqcet.edu.cn/uaa/login_process'  # 登陆url
info_url = 'http://ossc.cqcet.edu.cn/getUserInfo'  # 获取个人信息url
schedule_url = 'http://ossc.cqcet.edu.cn/api/schedule/query'  # 课表url

# 模拟登陆
headers = {
    'User-Agent': get_random_ua()
}

session = requests.session()

# 验证码图片下载
def getImgCode():
    img_name = str(uuid) + '.jpg'
    img_data = requests.get(url=code_url, headers=headers).content
    with open(img_name, 'wb') as fp:
        fp.write(img_data)
        print('验证码获取成功,请手动识别!')

2.5 具体过程

# 验证码图片下载
def getImgCode():
    img_name = str(uuid) + '.jpg'
    img_data = requests.get(url=code_url, headers=headers).content
    with open(img_name, 'wb') as fp:
        fp.write(img_data)
        print('验证码获取成功,请手动识别!')

# 判断是否需要输入验证码
isCode = session.get(url=url, headers=headers).text

if isCode == 'true':
    getImgCode()
    # 获取img_code
    img_code = input('请输入验证码:')
else:
    img_code = ''

data = {
    'type': '1',
    'deviceId': str(uuid),
    'username': username,
    'password': passwd,
    'img_code': img_code
}
response = session.post(url=login_url, data=data)
login_text = response.text
# print(response.status_code)  # 返回200表示模拟登陆成功了!

# 个人信息获取
info = session.get(url=info_url).text
info_data = json.loads(info)  # 将json字符串转为字典
# print(info_data)
# pprint.pprint(info_data)

contents += '亲爱的' + info_data['user']['name'] + '同学:\n'

# 课表获取
schedule_json = {
    'endDate': now_time,
    'limit': '10',
    'page': '1',
    'startDate': now_time,
    'type': '0'
}

schedule = session.post(url=schedule_url, json=schedule_json).text
schedule_data = json.loads(schedule)  # 将json字符串转为字典
# pprint.pprint(len(schedule_data['data'])) # 获取数组长度
# 判断是否有课
if len(schedule_data['data']) == 0:
    re_list = ['本来无一物,何处惹尘埃~', '今天没课,放松一下吧!', '小主,今日无课~\n可想好游玩之地?', '今日无课,无需早起~']
    contents += '        ' + re_list[random.randint(0, 3)]
else:
    contents += '&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;今日课表请查收~\n<hr/><table border="1" cellpadding="2" ' \
                'cellspacing="0"><tr><th>上课时间</th><th>课程名称</th><th>授课教师</th><th>上课地点</th></tr>'
    for course_table in schedule_data['data']:
        # print(course_table)
        time = '<tr><td>' + course_table['date'] + ' ' + course_table['time'] + '</td>'
        title = '<td>' + course_table['activity']['title'] + '</td>'
        teacher = '<td>' + course_table['activity']['remarks'] + '</td>'
        classroom = '<td>' + course_table['activity']['address'] + '</td></tr>'
        contents += time + title + teacher + classroom
contents += '</table>'

2.6 将获得的课表信息用邮件的方式发给自己

# 发送邮件函数
def to_mail(content):
    yag = yagmail.SMTP(
        user='sm*****e@qq.com',
        host='smtp.qq.com',
        password="pdxj**********", # 注意此处的密码不是你的邮箱密码,具体是什么。可以去百度一下yagmail的使用。
        smtp_ssl=True)
    yag.send(to=['3000004806@qq.com','s*****oe@qq.com'],
             subject='小主,你的课表来啦~',
             contents=contents)

to_mail(contents)  # 运行邮件发送函数

三、效果展示

到此这篇关于用Python获取智慧校园每日课表并自动发送至邮箱的文章就介绍到这了,更多相关Python获取课表后发送至邮箱内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • python+requests+pytest接口自动化的实现示例

    1.发送get请求 #导包 import requests #定义一个url url = "http://xxxxxxx" #传递参数 payload="{\"head\":{\"accessToken\":\"\",\"lastnotice\":0,\"msgid\":\"\"},\"body\":{\"user_name\&

  • 教你利用Selenium+python自动化来解决pip使用异常

    一.pip异常 有一小部分童鞋在打开cmd输入pip后出现下面情况:Did not provide a command Did not provide a command?这是什么鬼? 正常情况应该是酱紫 二.解决办法 1.pip是一个.exe的可执行文件,在cmd输入pip.exe就可以解决了 2.所以在后面的安装指令中都需要带上后缀,那么问题来了,为什么会出现这种情况,如何彻底解决? 三.配置环境变量 1.主要原因是环境变量的PATHEXT里面缺少.EXE的文件名 2.在PATHEXT下编辑

  • python自动化之如何利用allure生成测试报告

    Allure测试报告框架帮助你轻松实现"高大上"报告展示.本文通过示例演示如何从0到1集成Allure测试框架.重点展示了如何将Allure集成到已有的自动化测试工程中.以及如何实现报表的优化展示.Allure非常强大,支持多种语言多种测试框架,无论是Java/Python还是Junit/TestNG,其他语言或者框架实现的流程和本文一致,具体配置参照各语言框架规范 安装 安装allure Windows用户: scoop install allure    (需要先下载并安装Scoo

  • 十个Python自动化常用操作,即拿即用

    一.遍历文件夹 代码如下,大家可以根据自己的路径进行修改 import os      for dirpath, dirnames, filenames in os.walk(r'C:\\Program Files (x86)'):     print(f'打开文件夹{dirpath}') # 当前文件夹路径      if dirnames:         print(dirnames) # 包含文件夹名称[列表形式]      if filenames:         print(fil

  • 教你怎么用python selenium实现自动化测试

    一.安装selenium 打开命令控制符输入:pip install -U selenium 火狐浏览器安装firebug:www.firebug.com,调试所有网站语言,调试功能 Selenium IDE 是嵌入到Firefox 浏览器中的一个插件,实现简单的浏览器操 作的录制与回放功能,IDE 录制的脚本可以可以转换成多种语言,从而帮助我们快速的开发脚本,下载地址:https://addons.mozilla.org/en-US/firefox/addon/selenium-ide/ 如何

  • python办公自动化之excel的操作

    准备 使用 Python 操作 Excel 文件,常见的方式如下: xlrd / xlwt openpyxl Pandas xlsxwriter xlwings pywin32 xlrd 和 xlwt 是操作 Excel 文件最多的两个依赖库 其中, xlrd 负责读取 Excel 文件,xlwt 可以写入数据到 Excel 文件 我们安装这两个依赖库 # 安装依赖库 pip3 install xlrd  pip3 install xlwt  xlrd 读取 Excel 使用 xlrd 中的 o

  • Python实现网络自动化eNSP

    1.使用Paramiko登陆到单台交换机 实验拓扑 云彩桥接到本机环回接口:192.168.1.1/24 三层交换机IP:192.168.1.2/24 实验要求 使用Python Paramiko 模块实现SSH 登录单个交换机(192.168.56.2/24),配置LoopBack0地址:1.1.1.1/32.配置完成后,保存退出. 实验步骤 配置交换机管理地址,并测试与主机虚拟网卡连通性 [Huawei]vlan 10 [Huawei]int vlan 10 [Huawei-Vlanif10

  • Python 制作自动化翻译工具

    妈妈再也不用担心我的英语了. 一个可能你似曾相识的场景 阅读内容包含大量英文的 PPT.Word.Excel 或者记事本时,由于英语不熟悉,为了流利地阅读,需要打开浏览器进入谷歌翻译的主界面,然后把英文复制到谷歌翻译的输入框中,最后又把翻译结果复制回 PPT.Word 和 Excel. 要是一个两个单词还好,要是发现有 100 个单词不认识,就必须复制粘贴 200 次,如此机械性重复性的工作,应该交给程序来做,这就是我设计下面这个自动化翻译工具的初衷. 提升办公效率的法宝 如上图,运行程序并保持

  • 使用Gitee自动化部署python脚本的详细过程

    一.前期准备 1.1 安装环境 1.安装python3 2.打开命令行安装selenium pip install selenium 二.python代码 2.1 源码 #!/usr/bin/python # -*- coding: utf-8 -*- import time from selenium import webdriver from selenium.webdriver.common.alert import Alert # 模拟浏览器打开到gitee登录界面 driver = w

  • 使用Python自动化Microsoft Excel和Word的操作方法

    将Excel与Word集成,无缝生成自动报告 毫无疑问,微软的Excel和Word是公司和非公司领域使用最广泛的两款软件.它们实际上是"工作"的同义词.通常情况下,每一周我们都会将两者结合起来,并以某种方式发挥它们的优点.虽然一般的日常用途不会要求自动化,但有时自动化可能是必需的.也就是说,当您有大量的图表.图形.表格和报告要生成时,如果您选择手动方式,它可能会成为一项极其繁琐的工作.其实没必要这样.实际上,有一种方法可以在Python中创建一个管道,您可以将两者无缝集成,在Excel

随机推荐