日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

python自动下载邮件_python实现邮件自动化

發布時間:2023/12/10 python 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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实现邮件自动化的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。