admin管理员组文章数量:1559090
因为有需求,所以自己就稍微琢磨了一下这个东西,然后代码是从网上找的,目前我已经自测过是可以使用的,而且非常方便省事,这里分享给大家!
直接上代码:
# _*_ coding: utf-8 _*_
import poplib
import email
import os
from email.parser import parser
from email.header import decode_header
from email.utils import parseaddr
def decode_str(s):
value, charset = decode_header(s)[0]
if charset:
if charset == 'gb2312':
charset = 'gb18030'
value = value.decode(charset)
return value
def get_email_headers(msg):
headers = {}
for header in ['from', 'to', 'cc', 'subject', 'date']:
value = msg.get(header, '')
if value:
if header == 'date':
headers['date'] = value
if header == 'subject':
subject = decode_str(value)
headers['subject'] = subject
if header == 'from':
hdr, addr = parseaddr(value)
name = decode_str(hdr)
from_addr = u'%s <%s>' % (name, addr)
headers['from'] = from_addr
if header == 'to':
all_cc = value.split(',')
to = []
for x in all_cc:
hdr, addr = parseaddr(x)
name = decode_str(hdr)
to_addr = u'%s <%s>' % (name, addr)
to.append(to_addr)
headers['to'] = ','.join(to)
if header == 'cc':
all_cc = value.split(',')
cc = []
for x in all_cc:
hdr, addr = parseaddr(x)
name = decode_str(hdr)
cc_addr = u'%s <%s>' % (name, addr)
cc.append(to_addr)
headers['cc'] = ','.join(cc)
return headers
def get_email_content(message, savepath):
attachments = []
for part in message.walk():
filename = part.get_filename()
if filename:
filename = decode_str(filename)
data = part.get_payload(decode=true)
abs_filename = os.path.join(savepath, filename)
attach = open(abs_filename, 'wb')
attachments.append(filename)
attach.write(data)
attach.close()
return attachments
if __name__ == '__main__':
# 账户信息
email = 'sunn@nfu.edu'
password = 'sunxxx'
pop3_server = 'imap.exmail.qq'
# 连接到pop3服务器,带ssl的:
server = poplib.pop3_ssl(pop3_server)
# 可以打开或关闭调试信息:
server.set_debuglevel(0)
# pop3服务器的欢迎文字:
print(server.getwelcome())
# 身份认证:
server.user(email)
server.pass_(password)
# stat()返回邮件数量和占用空间:
msg_count, msg_size = server.stat()
print('message count:', msg_count)
print('message size:', msg_size, 'bytes')
# b' ok 237 174238271' list()响应的状态/邮件数量/邮件占用的空间大小
resp, mails, octets = server.list()
for i in range(1, msg_count):
resp, byte_lines, octets = server.retr(i)
# 转码
str_lines = []
for x in byte_lines:
str_lines.append(x.decode())
# 拼接邮件内容
msg_content = '\n'.join(str_lines)
# 把邮件内容解析为message对象
msg = parser().parsestr(msg_content)
headers = get_email_headers(msg)
attachments = get_email_content(msg, r'/users/sun/desktop')
print('subject:', headers['subject'])
print('from:', headers['from'])
print('to:', headers['to'])
if 'cc' in headers:
print('cc:', headers['cc'])
print('date:', headers['date'])
print('attachments: ', attachments)
print('-----------------------------')
server.quit()
这里主要说明2点:
-
对应代码中的69-71行,需要分别改成自己的邮箱、邮箱密码、邮箱对应的收件pop3服务器。
比如,我使用的是腾讯企业邮箱,那么我的pop3_server就是:
a、收件服务器:imap.exmail.qq,使用ssl,端口号993b、发件服务器:smtp.exmail.qq,使用ssl,端口号465
https://m.dingtalk/qidian/help-keyword-4088
-
第二个需要更改的地方就是对应代码的99行,改成你需要保存的文件的本地路径。
经过本人测试,可正常运行程序!
以上如何附件中的文件命名后缀名都是规范的话,不是出现解码出错的问题,但是我下载的附件中我发现有一个.jpg,是大写字母的话好像就无法正确解码。
发生异常: unicodedecodeerror
'utf-8' codec can't decode byte 0xff in position 0: invalid start byte
总结,文件规范命名基本上不会出现这样的下载错误。
最后附上代码的源作者:感谢作者,如有侵权,立刻删!
https://blog.csdn/ghostresur/article/details/81875574?spm=1001.2101.3001.6650.2&utm_medium=distribute.pc_relevant.none-task-blog-2~default~blogcommendfrombaidu~default-2.pc_relevant_default&depth_1-utm_source=distribute.pc_relevant.none-task-blog-2~default~blogcommendfrombaidu~default-2.pc_relevant_default&utm_relevant_index=5
大家觉得还不错的话给个小❤️❤️~~~
九游网址的版权声明:本文标题:利用python 脚本实现腾讯企业邮箱附件的批量下载 内容由热心网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:https://www.elefans.com/dongtai/1727421650a1113649.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论