python实现批量解析邮件并下载附件
作者:funny75 发布时间:2023-07-05 02:32:16
标签: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)
注:邮件名称中出现中文时需特别小心
来源:https://blog.csdn.net/funny75/article/details/50405220


猜你喜欢
- 1,模块命名(1)模块推荐使用小写命名,(2)除非有很多字母,尽量不要用下划线因为很多模块文件存与模块名称一致的类,模块采用小写,类采用首字
- 本文实例讲述了Python基于socket模块实现UDP通信功能。分享给大家供大家参考,具体如下:一 代码1、接收端import socke
- 我发现有的网站利用了SQL SERVER提供的通过EXCHANGE或OUTLOOK收发邮件的扩展存储过程来完成收发和自动处理邮件(这句话太长
- 今天的第二个作品,哈哈哈哈,搞起来感觉还挺有意思的,不过代码里纸牌J,Q,K,A几个数字被我替换成了11,12,13,14......主要是
- 一、为什么要进行包管理?python中的三方包琳琅满目,提供了各种各样的功能,使得我们免于自己去手写很多代码。比如,我们在测试接口的时候,我
- 1、利用uuid函数生成唯一且不规则的主键idsql:CREATE TABLE `test` ( `id` varchar(10
- 正常的使用方法安装npm install webpack-bundle-analyzer -Dwebpack.config.js:vue-c
- 国外纷纷传言IE8将是Internet Explorer的最后一个版本,这个猜测来源于Microsoft的CEO Steve
- 本文研究的主要是Python使用requests发送POST请求的相关内容,具体介绍如下。一个http请求包括三个部分,为别为请求行,请求报
- 钟馗之眼是一个强大的搜索引擎,不同于百度谷歌,它主要收集网络中的主机,服务等信息,国内互联网安全厂商知道创宇开放了他们的海量数据库,对之前沉
- 通过status命令,查看Slow queries这一项,如果值长时间>0,说明有查询执行时间过长以下为引用的内容:mysql>
- wxpython最为一款python GUI库,由于简单和轻便外加强大的功能而受到很多python爱好者的喜爱,pymysql作为pytho
- 一、uni.navigateTo(OBJECT)保留当前页面,跳转到应用内的某个页面,使用uni.navigateBack可以返回到原页面u
- 前言上篇介绍了go-grpc-middleware的grpc_zap、grpc_auth和grpc_recovery使用,本篇将介绍grpc
- 1.先找到迁移服务器上的Data文件,我安装的是mysql5.7,默认安装的路径。那么就是在C:\ProgramData\MySQL文件里面
- class SLTimer(multiprocessing.Process): #from dateti
- 一 MySQL WorkbenchMySQL Workbench提供DBAs和developers一个集成工具环境:1)数据库设计和建模2)
- 本文给出了MySQL数据库中定义外键的必要性、具体的定义步骤和相关的一些基本操作,供大家参考!定义数据表假如某个电脑生产商,它的数据库中保存
- 前言Qt 自带的工具提示样式不太好看,就算加了样式表也时不时会失效,同时工具提示没有阴影,看起来就更难受了。所以本篇博客将会介绍自定义工具提
- 在定义类的过程中,无论是显式创建类的构造方法,还是向类中添加实例方法,都要求将 self 参数作为方法的第一个参数。例如,定义一个 Pers