python 自动监控最新邮件并读取的操作
作者:姜小丫 发布时间:2023-02-04 12:58:51
标签:python,自动监控,邮件
我就废话不多说了,大家还是直接看代码吧~
#zmail库:可以用几行代码帮我们收取一封邮件
import zmail
#输入账号和密码
server=zmail.server('13163964546@qq.com','jie110341')
#获取最新的一封邮件
mail=server.get_latest()
#读取邮件
#zmail.show(mail)
#读取邮件的部分内容
print(mail['subject'])
......
#读取附件 邮件 存放路径 如果有同名文件则覆盖
zmail.save_acctachment(mail,target_path=None,overwrite=True)
需要在电脑上下载zmail库
补充:Python邮箱实施监控电脑
我就废话不多说了,大家还是直接看代码吧~
import smtplib
import poplib
import email
from email.mime.application import MIMEApplication
from email.mime.multipart import MIMEMultipart
from email.mime.text import MIMEText
from email.header import decode_header
def send_email(account, password, email_title, send_text="", file_names=None, file_dir="."):
msg = MIMEMultipart()
# msg = MIMEText(HTML, 'html') -- 只能发送文本内容
content = MIMEText(send_text, "plain", "utf-8")
msg.attach(content)
# 文件类型
if isinstance(file_names, list):
for file_name in file_names:
send_file_path = file_dir + "/" + file_name
part = MIMEApplication(open(send_file_path, 'rb').read())
part.add_header('Content-Disposition', 'attachment', filename=file_name)
msg.attach(part)
elif isinstance(file_names, str):
send_file_path = file_dir + "/" + file_names
part = MIMEApplication(open(send_file_path, 'rb').read())
part.add_header('Content-Disposition', 'attachment', filename=file_names)
msg.attach(part)
# msg['from'],msg['to']接收端显示的发件人与收件人
msg['from'] = "奥巴马@163.com"
msg['to'] = account
msg['subject'] = email_title
try:
server = smtplib.SMTP()
server.connect('smtp.163.com')
server.login(account, password)
# from_addr:发送地址; to_addrs:接收地址(字符串列表)
server.sendmail(account, msg['to'].split(), msg.as_string())
except Exception as e:
print(e)
# 获取邮件标题
def get_email_subject(addr, password):
# 设置连接网址,获取pop3协议的邮件读取对象
read = poplib.POP3('pop.163.com', timeout=3600)
# 输入邮件地址与邮件登录密码
read.user(addr) # 163邮箱用户名
read.pass_(password) # 163邮箱设置中的客户端授权密码
# allEmails = (totalNum, totalSize)
# 读取邮件信息(邮件总数,邮件尺寸)
total_num, total_size = read.stat()
# top(which,howmuch)
# 获取最新的一封邮件(第几封邮件,获取多少封)
top_email = read.top(total_num, 1)
# print("***** start *****\n接收的数据为: {}\n***** end *****\n".format(top_email))
#
# print("***** start *****\n[解码前]获取的初始邮件内容: {}\n***** end *****\n".format(top_email[1]))
# 解码邮件信息,将解码后的邮件信息存入tmp
tmp = []
for s in top_email[1]:
tmp.append(s.decode())
# print("***** start *****\n[解码后]的邮件内容为: {}\n***** end *****\n".format(tmp))
# 将解码后的邮件内容拼接为字符串
email_str = '\n'.join(tmp)
# 将字符串类型解析为Message类型
message = email.message_from_string(email_str)
# print("***** start *****\n"
# "[解码前]的邮件字符串内容为: [数据类型]{}\n{}\n"
# "--------------------------------------------\n"
# "[解码后]的邮件字符串内容为: [数据类型]{}\n{}\n"
# "***** end *****\n"
# .format(type(email_str), email_str, type(message), message))
# 获取邮件主题
subject_str = message['subject']
# print("***** start *****\n[解码前]邮件标题: {}\n***** end *****\n".format(subject_str))
subject = decode_header(subject_str)
# print("***** start *****\n[解码后]邮件标题: {}\n***** end *****\n".format(subject))
content = subject[0][0]
enc_type = subject[0][1]
if enc_type:
subject_decode = content.decode(enc_type)
else:
subject_decode = content
return subject_decode, read, total_num
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。如有错误或未考虑完全的地方,望不吝赐教。
来源:https://blog.csdn.net/weixin_45554040/article/details/102991398


猜你喜欢
- 临近春节,脚本之家小编带领大家用Python抢火车票!首先我们需要splinter安装:pip install splinter -i ht
- Mysql索引索引介绍索引是什么官方介绍索引是帮助MySQL高效获取数据的数据结构。更通俗的说,数据库索引好比是一本书前面的目录,能加快数据
- 我和朋友都建了一个电子商务网站,大量的访问,频繁地建立和中断数据库连接,导致Web 数据库应用程序降低了数据库服务器的性能。但最近,朋友使用
- 在tensorflow中,有三种方式输入数据1. 利用feed_dict送入numpy数组2. 利用队列从文件中直接读取数据3. 预加载数据
- while循环只要循环条件为True(以下例子为x > y),while循环就会一直 执行下去:u, v, x, y = 0, 0,
- 数据库操作语句 7. 外连接——交叉查询 7.1 查询 7.2 等值连接 7.3&nb
- 我们在做自动化运维的时候,经常需要调用api中的接口,不过很多人不知道具体的调用方法,在学习python中的requests库后,我们就可以
- html_downloaderfrom urllib import requestdef download(url): &nb
- 我认为在ASP中最好的办法是用编程实现定时刷新Cache,也就是说给Application中储存的设一个过期时间。当然,在ASP中Appli
- 前言:python在同一个线程中多次执行同一方法时,该方法执行耗时较长且每次执行过程及结果互不影响,如果只在主进程中执行,效率会很低,因此使
- (一)深入浅出理解索引结构 实际上,您可以把索引理解为一种特殊的目录。微软的SQL SERVER提供了两种索引:聚集索引(clus
- 本文所述为C#实现的Oracle数据库操作类,可执行超多常用的Oracle数据库操作,包含了基础数据库连接、关闭连接、输出记录集、执行Sql
- PyQt5+requests实现一个车票查询工具,供大家参考,具体内容如下结构图效果图思路1、search(QPushButton)点击信号
- *#type.jsfunction Person(name, age) { this.name = name; this
- 导航标签彼此互斥、完全穷尽。导航标签其实就是一种文字表达形式,我们用标签来代表网站上的各种分类信息。比如“联系我们”这个标签,代表的内容通常
- 对于个人站长来说,如何能使自己的网站与众不同、充满个性,一直是不懈努力的目标。除了尽量提高页面的视觉效果、互动功能以外,如果能在打开网页的同
- Django中的中间件是一个轻量级、底层的插件系统,可以介入Django的请求和响应处理过程,修改Django的输入或输出。中间件的设计为开
- 本文系统的对HTTP Headers进行了简明易懂的阐述,我仅稍作笔记。什么是HTTP HeadersHTTP是“Hypertext Tra
- 如果可以减少过多的外部隔离的API和简化部署的细节 这会是非常好的。在以前的文章中,我解释了"一些使用反向代理的好处&
- juypter notebook中直接使用log_device_placement=True打印不出来device信息# Creates a