溫馨提示×

溫馨提示×

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

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

Python批量發(fā)郵件--加附件/抄送

發(fā)布時(shí)間:2020-06-11 17:55:15 來源:網(wǎng)絡(luò) 閱讀:2735 作者:295631788 欄目:開發(fā)技術(shù)
# !/usr/bin/env python
# -*- coding: UTF-8 -*-
import csv
from email.mime.multipart import MIMEMultipart
from email.mime.text import MIMEText
from email.mime.application import MIMEApplication
from email.utils import COMMASPACE, formatdate
from email.mime.base import MIMEBase
from email import encoders
import time


def send_mail(server, fro, to, subject, text, chao):
    assert type(server) == dict
    assert type(to) == list
    msg = MIMEMultipart()
    msg['From'] = fro
    msg['Subject'] = subject
    msg['To'] = COMMASPACE.join(to)  # COMMASPACE==', '
    msg['Cc'] = chao  # COMMASPACE==', '
    msg['Date'] = formatdate(localtime=True)
    
    
    
    xlsxpart = MIMEBase("application", "msword")
    xlsxpart.set_payload(open(u'通知.docx','rb').read(), 'utf-8')
    xlsxpart.add_header('Content-Disposition', u'p_w_upload', filename="通知.docx")
    msg.attach(xlsxpart)
    
    
    
    import smtplib
    smtp = smtplib.SMTP(server['name'], server['port'])
    smtp.ehlo()
    smtp.starttls()
    smtp.ehlo()
    smtp.login(server['user'], server['passwd'])
    smtp.sendmail(fro, to+[chao], msg.as_string())
    smtp.close()
    
    
if __name__ == '__main__':
    server = {'name': 'xx.163.com', 'user': 'xxxxx', 'passwd': 'xxx', 'port': 25}
    fro = 'xxxxxxxx'
    subject = 'xxxxx'
    with open('1.csv', 'U') as csvfile:
        # reader = csv.DictReader(csvfile)
        reader = csv.reader(csvfile)
        l = []
        for row in reader:
            l.append(row)
    print("開始")
    for i in l:
        name = i[0]
        mail = i[2:10]
        chao = i[1]
        b = '''
        您好!
        值此“八一”建軍節(jié)之際,祝愿貴公司蓬勃發(fā)展,建軍節(jié)快樂!
                                                                                     
            '''
        a = "尊敬的{0}:".format(name)
        text = a + b
        while '' in mail:
            mail.remove('')
        to = mail
        print('to', to, 'ok', 'chao', chao, 'ok')
        time.sleep(7)
        send_mail(server, fro, to, subject, text, chao)



1.csv 的格式

第一列是客戶名稱,第二列是抄送的人,第三列和后面的是要發(fā)送的人。


 msg['To'] = COMMASPACE.join(to)  # COMMASPACE==', '
msg['Cc'] = chao  # COMMASPACE==', '
smtp.sendmail(fro, to+[chao], msg.as_string())

需要特別注意的是上面,抄送的是 1個(gè)人。


Cc 是指要抄送,要注意抄送的是一個(gè)人還是多個(gè)。如果是多個(gè),需要按照to的格式。



本腳本有BUG,就是收附件的時(shí)候,如果附件是中文名字,手機(jī)客戶端收的時(shí)候會顯示一個(gè) 未命名。電腦客戶端沒有問題。


暫未解決。






向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI