[Python] 利用Python做定时任务, 及时了解互联网动态
前言
本人因为比较喜欢看漫画和动漫, 所以总会遇到一些问题, 因为订阅的漫画或者动漫太多, 总会忘记自己看到那一章节或者不知道什么时候更新. 故会有这么一个需求, 想记录自己想看的漫画或动画并在其更新的时候第一时间知道,
当然, 你可以拓展到任何你想关注的, 都可以通过邮件及时推送.
思路


目录

运行环境
- Python3.6
- 第三方库
fake-useragent==0.1.11
pyquery==1.4.0
requests==2.21.0
pip3 install -r requirements.txt -i http://pypi.douban.com/simple
实现
获取全部代码, 请移步: Github
git clone https://github.com/Amd794/Checkupdate.git
邮件发送
需要用到smtplib发送邮件和email构造邮件.
SMTP是发送邮件的协议,Python内置对SMTP的支持,可以发送纯文本邮件、HTML邮件以及带附件的邮件。
下面来构造一封完整的邮件, 首先导入需要用到的方法或类:
from email import encoders
from email.header import Header
from email.mime.text import MIMEText
from email.utils import parseaddr, formataddrimport smtplib
然后, 我们先构造好头部, 工欲善其事,必先利其器
# 发送人
from_name = 'Amd794'
# 发送人邮箱
from_addr = '2952277346@qq.com'
# 发送人密码
password = '你的密码'
# 收件人
to_name = 'Your'
# 收件人邮箱
to_addr = '2952277346@qq.com'
# 邮箱服务
smtp_server = 'smtp.qq.com'
这里用到QQ的SMTP服务, 你也可以换成你喜欢的, 比如163, Google 等, 自选
但是你必须开启邮箱的SMTP服务, 下面来介绍下QQ邮箱打开服务的方法
- 你需要登录你的qq邮箱账号, https://mail.qq.com/

- 登录后, 点击设置

- 然后点击账户

- 滑动滚轮, 找到如下所示, 我是已经开了, 你只需要点击开启, 然后按说明一步一步就行

- 然后再点击生成授权码, 将得到的密码, 填到上面的password 字段


这样, 头部就构造好了
然后, 构造发送体
def _contact(self, msg, from_addr, to_addr, title):
msg['From'] = self._format_addr('%s <%s>' % (from_name, from_addr))
msg['To'] = self._format_addr('%s <%s>' % (to_name, to_addr))
msg['Subject'] = Header(title, 'utf-8').encode()
msg = MIMEText(content, 'plain', 'utf-8')
_contact(msg, from_addr, to_addr, title)
发送邮件
server = smtplib.SMTP(smtp_server, 25)
server.set_debuglevel(1)
server.login(from_addr, password)
server.sendmail(from_addr, [to_addr], msg.as_string())
server.quit()
发送成功

更新检测
思路是通过, 获取云端数据 然后 通过与本地缓存 对比, 得到更新情况
构造本地数据, 自定义自己想要订阅的漫画, 格式 平台-名称-链接
# 支持平台 漫画台, 土豪漫画, 腾讯漫画,腾讯视频 对应 Manhuatai Tohomh123 TencentComic TencentVedio
ComecDict = {
'Manhuatai-武动乾坤': 'https://www.manhuatai.com/wudongqiankun',
'Manhuatai-斗破苍穹': 'https://www.manhuatai.com/doupocangqiong',
'Tohomh123-妖神记': 'https://www.tohomh123.com/yaoshenji/',
'Manhuatai-大主宰': 'https://www.manhuatai.com/dazhuzai',
'TencentComic-海贼王': 'https://ac.qq.com/Comic/comicInfo/id/505430',
'Tohomh123-全职法师': 'https://www.tohomh123.com/quanzhifashi/',
'Tohomh123-永恒至尊': 'https://www.tohomh123.com/yonghengzhizun/',
'TencentVedio-万界神主': 'https://v.qq.com/x/cover/y0jueuihog64xhb/j0030ajsgq9.html',
'TencentVedio-斗罗大陆': 'https://v.qq.com/x/cover/m441e3rjq9kwpsc/r0030jqn37g.html',
'TencentVedio-狐妖小红娘': 'https://v.qq.com/x/cover/0sdnyl7h86atoyt.html',
'TencentVedio-万界仙踪 第2季' : 'https://v.qq.com/x/cover/7s65u4bg66so7e6/y0030u40wuu.html',
'TencentVedio-天行九歌' : 'https://v.qq.com/x/cover/rm3tmmat4li8uul/w0030phkr6h.html',
}
最后检测实现, 部分代码:
def main():
# 支持的平台
paltfromList = {
'Manhuatai': Manhuatai, # 漫画台
'TencentComic': TencentComic, # 腾讯动漫平台
'Tohomh123': Tohomh123, # 土豪漫画平台
'TencentVedio': TencentVedio, # 腾讯视频
}
with open('datas.json', encoding='utf-8') as fr: # 读取本地漫画状态
datas = json.load(fr)
for key, value in ComecDict.items():
try:
paltfrom, key = key.split('-')
obj = paltfromList.get(paltfrom)().run(value) # 获取漫画最新更新状态
if obj:
content, url = obj
new_data = content # 最新章节数据
old_data = datas.get(key, None) # 本地章节数据
if old_data != new_data: # 判断是否有更新
datas[key] = content # 更新本地章节 with open('template.html', encoding='utf-8') as f:
tx = f.read().format(url=url, new_data=new_data, old_data=old_data) # 构造邮件内容 SendEmail(content=tx, title='{key} 更新通知'.format(key=key),
emtype='htmlcontent').sendEmail() # 发送邮件, 推送更新 with open('datas.json', 'w', encoding='utf-8') as fw: # 存储更新后的状态
json.dump(datas, fw, ensure_ascii=False, indent=4, separators=(', ', ': '))
else:
print('\033[22;35;m {} \033[m 暂无更新, 当前章节: \033[22;35;m {} \033[m'.format(key, old_data))
except TypeError:
print('检测{key}失败, 该平台没有{key}, 或者平台配置有误'.format(key=key))
except Exception:
SendEmail(content=traceback.format_exc(),
title='获取 {key} 时脚本异常通知'.format(key=key)).sendEmail() # 发送邮件, 脚本异常
最终效果


[Python] 利用Python做定时任务, 及时了解互联网动态的更多相关文章
- Python 利用Python操作excel表格之openyxl介绍Part2
利用Python操作excel表格之openyxl介绍 by:授客 QQ:1033553122 欢迎加入全国软件测试交流qq群(群号:7156436) ## 绘图 c = LineChart() ...
- Python 利用Python操作excel表格之openyxl介绍Part1
利用Python操作excel表格之openyxl介绍 by:授客 QQ:1033553122 欢迎加入全国软件测试交流qq群(群号:7156436),免费获取以下性能监控工具(类似Nmon精简版) ...
- Python 利用Python操作excel表格之xlwt介绍
利用Python操作excel表格之xlwt介绍 by:授客 QQ:1033553122 直接上代码 案例1 #!/usr/bin/env python # -*- coding:utf-8 ...
- Python 利用Python编写简单网络爬虫实例3
利用Python编写简单网络爬虫实例3 by:授客 QQ:1033553122 实验环境 python版本:3.3.5(2.7下报错 实验目的 获取目标网站“http://bbs.51testing. ...
- Python 利用Python编写简单网络爬虫实例2
利用Python编写简单网络爬虫实例2 by:授客 QQ:1033553122 实验环境 python版本:3.3.5(2.7下报错 实验目的 获取目标网站“http://www.51testing. ...
- python 利用python的subprocess模块执行外部命令,获取返回值
有时执行dos命令需要保存返回值 需要导入库subprocess import subprocess p = subprocess.Popen('ping www.baidu.com', shell= ...
- 了解python,利用python来制作日常猜拳,猜价小游戏
初次接触python,便被它简洁优美的语言所吸引,正所谓人生苦短,python当歌.python之所以在最近几年越发的炽手可热,离不开它的一些特点: 1.易于学习:Python有相对较少的关键字,结构 ...
- Python: 利用Python进行数据分析 学习记录
-----15:18 2016/10/14----- 1. import numpy as np;import pandas as pd values = pd.Series(np.random.no ...
- 《利用python进行数据分析》读书笔记 --第一、二章 准备与例子
http://www.cnblogs.com/batteryhp/p/4868348.html 第一章 准备工作 今天开始码这本书--<利用python进行数据分析>.R和python都得 ...
随机推荐
- eclipse中集成velocity插件
1.打开eclipse,点击help,选择install new software 2.点击add,输入下载地址: http://download.eclipse.org/eclipse/update ...
- C++拷贝构造函数(深拷贝,浅拷贝)
http://www.cnblogs.com/BlueTzar/articles/1223313.html C++拷贝构造函数(深拷贝,浅拷贝) 对于普通类型的对象来说,它们之间的复制是很简单的,例如 ...
- Android_微信_设置
减少 内存的使用 (http://news.ifeng.com/a/20170716/51440541_0.shtml) 1.关闭“附近的人” 打开微信,依次点击[我]—[设置]—[通用]—[功能], ...
- Codeforces 402D Upgrading Array:贪心 + 数学
题目链接:http://codeforces.com/problemset/problem/402/D 题意: 给你一个长度为n的数列a[i],又给出了m个“坏质数”b[i]. 定义函数f(s),其中 ...
- BZOJ 3357 [Usaco2004]等差数列:map优化dp
题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=3357 题意: 给你n个数a[i],让你找出一个最长的是等差数列的子序列. 题解: 表示状态 ...
- Delpih - Format
Format是一个很常用,却又似乎很烦的方法,本人试图对这个方法的帮助进行一些翻译,让它有一个完整的概貌,以供大家查询之用: 首先看它的声明:function Format(const Format: ...
- Oracle学习笔记_05_分组函数
组函数:avg sum max min count group by having group by 增强:rollup cube grouping groupi ...
- 宽度显示banner
今天解决了一个以前解决不了的问题,所以就想找博客园记录一些笔记. ……以前也遇到过这种满屏banner不知道怎么做的问题,问老师老师也说不出个所以然,百度搜了好几条 也不太满意... 所以就开始尝试摸 ...
- myeclipes如何调试web项目
你可以右击项目,然后选中那个debug as,然后选择open debug dialog,在project中选择要运行的项目,sever中选择服务器,然后单击debug就ok了,,
- Oracle--存储过程和自定义函数
一.相关概念 1.存储过程和存储函数 ~指存储在数据库中供所有用户程序调用的子程序 ~存储过程和存储函数的相同点:完成特定功能的程序 ~存储过程和存储函数区别:是否用return语句返回值 2.创建和 ...