91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

python+POP3實現批量下載郵件附件

發布時間:2020-10-13 20:43:02 來源:腳本之家 閱讀:381 作者:li_huifei 欄目:開發技術

最近新開學,接到了給老板的本科課程當助教的工作,百十來號人一學期下來得有四五次作業發進郵箱里,需要我來統計打分,想想挨個點進去下載附件的過程就頭大,于是萌生了寫個腳本來統計作業的想法。

其實python里收發郵件都有很方便的包,合理使用就好,可以解決絕大多數的郵件收發任務。但是這個腳本寫下來還是花了不少時間,其中最大的一部分時間是花在了python的編碼問題上,python2和python3的編碼預設有些許的不一樣,在python3中又取消了unicode這個方法,這就導致很多在python2中寫的例程都沒法在3中運行。

經過修改以后下面的腳本可以從郵箱中獲取指定日期范圍內的郵件附件,并存如指定目錄中。

#!/usr/bin/env python3 
# -*- coding: utf-8 -*- 
import poplib 
import email 
import datetime 
import time 
import os 
import xlrd 
import xlwt 
from email.parser import Parser 
from email.header import decode_header 
from email.utils import parseaddr 
 
 
 
# 輸入郵件地址, 口令和POP3服務器地址: 
email = 'xxxxxxxx@qq.com' 
password = 'xxxxxxxxxxx' 
pop3_server = 'pop.qq.com' 
 
 
 
def decode_str(s):#字符編碼轉換 
  value, charset = decode_header(s)[0] 
  if charset: 
    value = value.decode(charset) 
  return value 
 
 
def get_att(msg): 
  import email 
  attachment_files = [] 
   
  for part in msg.walk(): 
    file_name = part.get_filename()#獲取附件名稱類型 
    contType = part.get_content_type() 
     
    if file_name:  
      h = email.header.Header(file_name) 
      dh = email.header.decode_header(h)#對附件名稱進行解碼 
      filename = dh[0][0] 
      if dh[0][1]: 
        filename = decode_str(str(filename,dh[0][1]))#將附件名稱可讀化 
        print(filename) 
        #filename = filename.encode("utf-8") 
      data = part.get_payload(decode=True)#下載附件 
      att_file = open('E:\\L\\zy\\307\\' + filename, 'wb')#在指定目錄下創建文件,注意二進制文件需要用wb模式打開 
      attachment_files.append(filename) 
      att_file.write(data)#保存附件 
      att_file.close() 
  return attachment_files 
 
     
       
# 連接到POP3服務器,有些郵箱服務器需要ssl加密,對于不需要加密的服務器可以使用poplib.POP3() 
server = poplib.POP3_SSL(pop3_server) 
server.set_debuglevel(1) 
# 打印POP3服務器的歡迎文字: 
print(server.getwelcome().decode('utf-8')) 
# 身份認證: 
server.user(email) 
server.pass_(password) 
# 返回郵件數量和占用空間: 
print('Messages: %s. Size: %s' % server.stat()) 
# list()返回所有郵件的編號: 
resp, mails, octets = server.list() 
# 可以查看返回的列表類似[b'1 82923', b'2 2184', ...] 
print(mails) 
index = len(mails) 
 
 
 
for i in range(index,0,-1): 
  #倒序遍歷郵件 
  resp, lines, octets = server.retr(i) 
  # lines存儲了郵件的原始文本的每一行, 
  #郵件的原始文本: 
  msg_content = b'\r\n'.join(lines).decode('utf-8') 
  #解析郵件: 
  msg = Parser().parsestr(msg_content) 
  #獲取郵件時間 
  date1 = time.strptime(msg.get("Date")[0:24],'%a, %d %b %Y %H:%M:%S') #格式化收件時間 
  date2 = time.strftime("%Y%m%d", date1)#郵件時間格式轉換 
  if (date2<'20180306')|(date2>'20180314'): 
     
    continue 
  f_list = get_att(msg)#獲取附件 
   
     
   
  #print_info(msg) 
 
server.quit() 

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

兖州市| 潮安县| 乐陵市| 日土县| 藁城市| 青龙| 全州县| 松溪县| 凤山市| 佛冈县| 繁峙县| 甘洛县| 神池县| 攀枝花市| 汾西县| 柳州市| 盐亭县| 碌曲县| 乐平市| 和平县| 荆州市| 察隅县| 渭南市| 娄烦县| 搜索| 额尔古纳市| 日照市| 舒城县| 南陵县| 时尚| 措勤县| 宜宾县| 曲阜市| 浦东新区| 昌吉市| 韶山市| 丰县| 周口市| 民勤县| 依安县| 高要市|