python自动下载邮件_python实现邮件自动化
1、自動接收郵件并且下載附件,使用pop3協議。
# 接收郵件并下載郵件附件
import poplib
import email
import datetime
import time
from email.parser import Parser
from email.header import decode_header
import traceback
import telnetlib
import sys
# from email.utils import parseaddr
class c_step4_get_email:
# 字符編碼轉換
@staticmethod
def decode_str(str_in):
value, charset = decode_header(str_in)[0]
if charset:
value = value.decode(charset)
return value
# 解析郵件,獲取附件
@staticmethod
def get_att(msg_in, str_day_in):
# import email
attachment_files = []
for part in msg_in.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 = c_step4_get_email.decode_str(str(filename, dh[0][1]))
print(filename)
# filename = filename.encode("utf-8")
# 下載附件
data = part.get_payload(decode=True)
# 在指定目錄下創建文件,注意二進制文件需要用wb模式打開
att_file = open(r'C:\Users\Administrator\Desktop\test' + '\\' + filename, 'wb')
attachment_files.append(filename)
att_file.write(data) # 保存附件
att_file.close()
return attachment_files
@staticmethod
def run_ing():
# 輸入郵件地址, 口令和POP3服務器地址:
email_user = 'zgcindex_zh@163.com'
# 此處密碼是授權碼,用于登錄第三方郵件客戶端
password = input('請輸入您的密碼:') #
pop3_server = 'pop.163.com'
# 日期賦值
day = datetime.date.today() - datetime.timedelta(days=1)#周一days=3
str_day = str(day).replace('-', '')
print(str_day)
# 連接到POP3服務器,有些郵箱服務器需要ssl加密,可以使用poplib.POP3_SSL
try:
telnetlib.Telnet('pop.163.com', 995)
server = poplib.POP3_SSL(pop3_server, 995, timeout=10)
except:
time.sleep(5)
server = poplib.POP3(pop3_server, 110, timeout=10)
# server = poplib.POP3(pop3_server, 110, timeout=120)
# 可以打開或關閉調試信息
# server.set_debuglevel(1)
# 打印POP3服務器的歡迎文字:
print(server.getwelcome().decode('gb18030'))#utf-8
# 身份認證:
server.user(email_user)
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):
# 順序遍歷郵件
for i in range(index, index - 100, -1): # 1988, 1989 0,index+1,-1 index,index+1
resp, lines, octets = server.retr(i)
# lines存儲了郵件的原始文本的每一行,
# 郵件的原始文本:
msg_content = b'\r\n'.join(lines).decode('gb18030')#('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 < str_day:
# 倒敘用break
break
# 順敘用continue
# continue
else:
# 獲取附件
c_step4_get_email.get_att(msg, str_day)
# print_info(msg)
server.quit()
if __name__ == '__main__':
# @version : 3.4
# @Author : robot_lei
# @Software: PyCharm Community Edition
# log_path = 'C:\\fakepath\\log.log'
# logging.basicConfig(filename=log_path)
origin = sys.stdout
f = open(r'C:\Users\Administrator\Desktop\receive\123.txt', 'w')
sys.stdout = f
try:
c_step4_get_email.run_ing()
except Exception as e:
s = traceback.format_exc()
print(e)
tra = traceback.print_exc()
sys.stdout = origin
f.close()
2、自動按郵箱地址列批量發送excel文件,使用SMTP協議。
#按郵箱對應回復反饋郵件
from email.mime.text import MIMEText
import smtplib
from email.header import Header
from email.utils import parseaddr,formataddr#設置編碼格式
from email.mime.base import MIMEBase
from email.mime.multipart import MIMEMultipart
from email import encoders
import openpyxl
import pandas as pd
import time
time.strftime("%Y/%m/%d", time.localtime())
data_path = r"C:\Users\Administrator\Desktop\0807zongbiao.xlsx"
data = pd.read_excel(data_path)
reply_root_path = r"C:\Users\Administrator\Desktop\ttt"
# for email_id,value in data.groupby("發件人郵箱"):
# current_time = time.strftime("%Y%m%d", time.localtime())
# reply_path = reply_root_path + "\回復附件#" + current_time+ "#" + email_id + '.xlsx'
# value.reset_index(drop=True).to_excel(reply_path)
#打開excel文件,讀取郵箱地址和審核意見列
# wb=openpyxl.load_workbook(r'C:\Users\Administrator\Desktop\0801zongbiao.xlsx')
# sheet=wb.get_active_sheet()
# to_addrs=list(sheet.columns)[9]
# body=list(sheet.columns)[9]
#for item in list(sheet.columns)[10]:
#print(item.value)
#將用戶名編碼設置成UTF-8
def _format_addr(s):
name,addr=parseaddr(s)
return formataddr((Header(name, 'utf-8').encode(),addr))
#定義email的地址,口令和SMTP服務器地址
from_addr='zgcindex_zh@163.com'
password=input('請輸入發送郵箱的密碼:')#
smtp_server='smtp.163.com'
# to_addr='sx_wy123@163.com'
#定義郵件本身內容
# msg=MIMEMultipart()
# msg['From']=_format_addr('發送者的ReedSun'%from_addr)
# msg['To']=_format_addr('接收者的ReedSun'%to_addr)
# msg['Subject']=Header('回復','utf-8').encode()
#定義郵件正文
# msg.attach(MIMEText('使用python發來的郵件3','plain','utf-8'))
#加附件
for email_id,value in data.groupby("發件人郵箱"):
current_time = time.strftime("%Y%m%d", time.localtime())
reply_path = reply_root_path + "\回復附件#" + current_time+ "#" + email_id + '.xlsx'#文件名
value.reset_index(drop=True).to_excel(reply_path)
to_addr=email_id
msg=MIMEMultipart()
msg['From']=_format_addr('發送者的ReedSun'%from_addr)
msg['To']=_format_addr('接收者的ReedSun'%to_addr)
msg['Subject']=Header('總后審核意見','utf-8').encode()
msg.attach(MIMEText('總后新品申請審核意見,詳情請見附件!注:有多封申請郵件的公司,不再分別回復,統一一并回復到附件中!請大家一定按要求格式申請,否則可能會無法正常申請上架,謝謝配合~','plain','utf-8'))
with open(reply_path,'rb') as f:
# 設置附件的MIME和文件名,這里是jpg類型,可以換png或其他類型:
mime=MIMEBase("\回復附件#" + current_time+ "#" + email_id, 'xlsx', filename="\回復附件#" + current_time+ "#" + email_id + '.xlsx')
mime.add_header('Content-Disposition','attchment',filename=reply_path)
mime.add_header('Content-ID','<0>')
mime.add_header('X-Attachment-ID','0')
mime.set_payload(f.read())
encoders.encode_base64(mime)
msg.attach(mime)
#定義發送文件
server=smtplib.SMTP_SSL(smtp_server,465)
server.set_debuglevel(1)
server.login(from_addr,password)
server.sendmail(from_addr,to_addr,msg.as_string())
server.quit()
這次弄完之后發現python做一些重復事情自動化的事情真的是很有用呢~
找工作中,希望工作快砸來吧。
總結
以上是生活随笔為你收集整理的python自动下载邮件_python实现邮件自动化的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 华为P50 Pro能用5G了!中国联通首
- 下一篇: python去空格的函数_Python怎