[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都得 ...
随机推荐
- MySQL- 常用的MySQL函数,指令等
MySQL查看版本: status: 或者 select version(); //select @@version MySQL昨天, 一周前 ,一月前 ,一年前的数据 这里主要用到了 DATE_SU ...
- Http请求和响应
Http请求和响应 Http协议对浏览器发出的Request格式以及对Web服务器发出的Response格式有具体的规定. 请求部分由三部分组成: Requset line:请求行,位于第一行 Req ...
- asp.net中关于《%=》《%#》《%》 的用法——(转帖)
1:在.aspx页面,<% %>标签相当于在.cs页面的代码,也就是说你在.cs文件里面怎样写,就可以在.aspx文件里面的<% %>标签里面怎样写. 2:在.aspx页面,& ...
- I.MX6 Busybox watchdog
/************************************************************************* * I.MX6 Busybox watchdog ...
- freeMarker(二)——模板开发指南之入门
学习笔记,选自freeMarker中文文档,译自 Email: ddekany at users.sourceforge.net 模板开发指南-入门 1.模板+数据模型=输出 假设在一个在线商店的应 ...
- [BZOJ2780][SPOJ8093]Sevenk Love Oimaster
bzoj luogu 题面 给定n个模板串,以及m个查询串. 依次查询每一个查询串是多少个模板串的子串. sol 广义后缀自动机裸题? 先建出\(SAM\),然后记录一下每个节点分别在多少个模板串里出 ...
- bzoj 4261: 建设游乐场 费用流
题目 现在有一大块土地,可以看成N*M的方格.在这块土地上,有些格子内是崎岖的山地,无法建造任何东西:其他格子都是平原.现在打算在这块土地上建设一个游乐园.游乐园由若干条闭合的过山车轨道组成,每个平原 ...
- mysqllog
-- mysql delete log online 1 mysql命令purge mysql> purge master logs to "mysql-bin.000410&quo ...
- MySQL Explain详解(转)
explain SELECT a.* FROM test a,(select id from test where level_id <=4 order by aa_id limit 24300 ...
- 解决mysql 客户端连接问题
问题:在linux 上安装了mysql服务端,使用客户端连接时报错信息为:ERROR 1045 (28000): Access denied for user 'root'@'localhos ...