python实现批量解析邮件并下载附件
更新时间:2018年06月19日 15:18:57 作者:funny75
这篇文章主要为大家详细介绍了python实现批量解析邮件并下载附件,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
python中的email模块可以方便的解析邮件,先上代码
#-*- encoding: gb2312 -*-
import os
import email
def mail_to_text(mailname,datapath,index):
#由于批处理的邮件包含的附件名称相同,这里传入一个index作为区别符
fp=open(mailname,"r")
msg=email.message_from_file(fp)
for par in msg.walk():
if not par.is_multipart():
name=par.get_param("name") #获取附件名
if name:
h=email.Header.Header(name)
dh=email.Header.decode_header(h)
fname = dh[0][0]
data=par.get_payload(decode=True)
try:
f=open(fname,'wb')
except:
data_name=str(h).replace('/','_') #附件数据
f=open(datapath+'\\'+str(index)+data_name,'wb')
f.write(data)
f.close()
if __name__=='__main__':
dir="C:\\Users\\admin\\Desktop\\srcData\\" #邮件存放路径
Dir=unicode(dir,"utf8")
datapath="C:\\Users\\admin\\Desktop\\destData" #附件存放路径
DataPath=unicode(datapath,"utf8")
count=0
for filename in os.listdir(dir):
print filename
filename=unicode(dir+filename,"utf8") #由于邮件名出现中文,所以统一用utf8编码,便于读取
print filename
count+=1
mail_to_text(filename,datapath,count)
注:邮件名称中出现中文时需特别小心
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
Pandas:Series和DataFrame删除指定轴上数据的方法
今天小编就为大家分享一篇Pandas:Series和DataFrame删除指定轴上数据的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2018-11-11
Pytorch中torch.unsqueeze()与torch.squeeze()函数详细解析
torch.squeeze()这个函数主要对数据的维度进行压缩,去掉维数为1的的维度,下面这篇文章主要给大家介绍了关于Pytorch中torch.unsqueeze()与torch.squeeze()函数详细的相关资料,需要的朋友可以参考下2023-02-02


最新评论