- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章python 自动监控最新邮件并读取的操作由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
我就废话不多说了,大家还是直接看代码吧~ 。
1
2
3
4
5
6
7
8
9
10
11
12
13
|
#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邮箱实施监控电脑 。
我就废话不多说了,大家还是直接看代码吧~ 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
|
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 自动监控最新邮件并读取的操作的文章就讲到这里了,如果你想了解更多关于python 自动监控最新邮件并读取的操作的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
就目前情况而言,这个问题不太适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、民意调查或扩展讨论。如果您觉得这个问题可以改进并可能重新开放,visit
ECharts是一个纯Javascript的图表库,可以流畅的运行在PC和移动设备上,兼容当前绝大部分浏览器,底层依赖轻量级的Canvas类库ZRender,提供直观、生动、可交互、可高度个性化定制
前言 提示:这里可以添加本文要记录的大概内容: 例如:随着人工智能的不断发展,机器学习这门技术也越来越重要,很多人都开启了学习机器学习,本文就介绍了机器学习的基础内容。 提示:以下是本篇文章正文
作为一名ios开发攻城狮,在苹果没有出arc(自动内存管理机制)时,我们几乎有一半的开发时间都耗费在这么管理内存上.后来苹果很人性的出了arc,虽然在很大程度上,帮助我们开发者节省了精力和时间.但是
如何反转Pandas中DataSeries的排序顺序,以便我按降序使用它们? 最佳答案 In [28]: s = pd.Series([20, 10, 30], ['c', 'a', 'b']) In
这个问题已经有答案了: 已关闭10 年前。 Possible Duplicate: Is jQuery $.browser Deprecated? 最新的 jQuery 库是否发生变化 $.brows
我正在开发一个 Intranet 项目,所以我无法复制/粘贴代码,所以希望我的描述和一些小片段会有所帮助。 我知道 MySQL 触发器无法做到这一点,但希望有一种干净的 JPA PrePersist(
这是数据集: 人员状态日期 埃里克 1 1/1/2015 埃里克 2 2/1/2015 埃里克 3 2015 年 3 月 1 日 约翰福音 1 3/1/2015 约翰福音 2 2015 年 2 月 1
现在我正在使用下面的查询按每篇文章的 auto_increment id 排序 mysql_query("SELECT * FROM articles ORDER BY id DESC"); 我想知道
已结束。此问题不符合 Stack Overflow guidelines .它目前不接受答案。 我们不允许提出有关书籍、工具、软件库等方面的建议的问题。您可以编辑问题,以便用事实和引用来回答它。 关闭
已结束。此问题不符合 Stack Overflow guidelines .它目前不接受答案。 我们不允许提出有关书籍、工具、软件库等方面的建议的问题。您可以编辑问题,以便用事实和引用来回答它。 关闭
现在我正在使用下面的查询按每篇文章的 auto_increment id 排序 mysql_query("SELECT * FROM articles ORDER BY id DESC"); 我想知道
在我们做文章的时候常用一些函数修改来实现自己的页面效果,例如,时间的自定义格式 我们常常需要乃至的,搜集了些有关时间格式的CODE,作大家为参考,希望对大家有些帮助 列表页list_article
我想将某些东西提交到 github 存储库,但我(显然)没有任何权利这样做。我对那个 repo 做了一个分支,提交了我的更改并提交了一个 pull-request。 现在,问题是过了一段时间其他人已经
我是 SQL 新手,所以现有的答案对我来说有点复杂。 我有三张 table : WORKER |id |name |date |... JOB |id |name |salary |accept AP
我正在自动从PowerPoint和Excel电子表格中生成PowerPoint报表。在粘贴表格之前,我已经完成了整个过程。 我使用PPApp.CommandBars.ExecuteMso ("Past
我们有 1 个 Kafka 主题和 1 个分区: 从 spring boot kafka 消费者那里看到一个相当奇怪的行为。 Spring kafka消费者在重新启动时总是从主题的开头开始消费。 我已
通过编程从iOS照片库获取最新照片是否有技巧? 我知道我可以按日期搜索,但是我必须每隔一微秒进行一次扫描,以便进行某种比较以准确地找到它。 有没有人做过这个或任何想法? 最佳答案 我之前采取的一种方法
我们上周将 Web 应用程序中的 Telerik Kendo 库从 V2015.2.902 升级到 V2016.1.112。从那时起,我们注意到使用 Kendo 的页面需要很长时间才能加载(30 秒到
我有两个表: STUDENT GRADES ---------- ---------- id id name person_id ad
我是一名优秀的程序员,十分优秀!