python實現(xiàn)批量解析郵件并下載附件
更新時間:2018年06月19日 15:18:57 作者:funny75
這篇文章主要為大家詳細介紹了python實現(xiàn)批量解析郵件并下載附件,具有一定的參考價值,感興趣的小伙伴們可以參考一下
python中的email模塊可以方便的解析郵件,先上代碼
#-*- encoding: gb2312 -*-
import os
import email
def mail_to_text(mailname,datapath,index):
#由于批處理的郵件包含的附件名稱相同,這里傳入一個index作為區(qū)別符
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('/','_') #附件數(shù)據(jù)
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") #由于郵件名出現(xiàn)中文,所以統(tǒng)一用utf8編碼,便于讀取
print filename
count+=1
mail_to_text(filename,datapath,count)
注:郵件名稱中出現(xiàn)中文時需特別小心
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
Pandas:Series和DataFrame刪除指定軸上數(shù)據(jù)的方法
今天小編就為大家分享一篇Pandas:Series和DataFrame刪除指定軸上數(shù)據(jù)的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-11-11
Pytorch中torch.unsqueeze()與torch.squeeze()函數(shù)詳細解析
torch.squeeze()這個函數(shù)主要對數(shù)據(jù)的維度進行壓縮,去掉維數(shù)為1的的維度,下面這篇文章主要給大家介紹了關于Pytorch中torch.unsqueeze()與torch.squeeze()函數(shù)詳細的相關資料,需要的朋友可以參考下2023-02-02
Python aiohttp百萬并發(fā)極限測試實例分析
這篇文章主要介紹了Python aiohttp百萬并發(fā)極限測試,結合實例形式分析了Python異步編程基于aiohttp客戶端高并發(fā)請求的相關操作技巧與使用注意事項,需要的朋友可以參考下2019-10-10

