Python从csv列表发送电子邮件

时间:2015-05-16 01:48:33

标签: python python-2.7 python-3.x

我是python的新手,我正在尝试使用smtplib读取值发送电子邮件。这是我的csv文件的格式 -

Name,Email,Message  
A,a@email.com,Message1  
B,b@email.com,Message2  
C,c@email.com,Message3  

我需要提供一个Python脚本来读取csv列,并从电子邮件列向每个成员发送电子邮件,并在电子邮件正文中显示相应的消息文本

3 个答案:

答案 0 :(得分:2)

假设您正在使用Python-2.x。

您可以使用smtplib模块发送电子邮件,使用csv模块阅读csv文件。

此外,要使用smtplib,您必须拥有用于发送电子邮件的电子邮件地址,无论电子邮件是Yahoo邮件还是Gmail或其他任何内容。

一些示例代码如下:

#!/usr/bin/python

import csv
import smtplib
from email.mime.text import MIMEText
from email.Header import Header

def sendmail(info_list):
    msg = MIMEText(info_list[2], "html", "utf-8")
    msg['Subject'] = Header("YOUR SUBJECT", "utf-8")
    msg['From'] = "FROM_WHOM@XXX.com"
    msg['To'] = info_list[1]
    s = smtplib.SMTP("smtp.XXX.com")
    s.ehlo()
    s.starttls()
    s.login("YOUR EMAIL USERNAME", "YOUR EMAIL PASSWORD")
    s.sendmail("FROM_WHOM", info_list[1], msg.as_string())

def main():
    with open("msg.csv", "rb") as csvfile:
        msg_reader = csv.reader(csvfile)
        msg_reader.next()
        map(lambda x: sendmail(x), msg_reader)

if __name__ == "__main__":
    main()

答案 1 :(得分:1)

Python附带了一个名为smtplib的强大模块。它用于简单邮件传输协议。

import smtplib
sender = 'from@fromdomain.com'
receivers = ['to@todomain.com']

message = """From: From Person <from@fromdomain.com>
To: To Person <to@todomain.com>
Subject: SMTP e-mail test

This is a test e-mail message.
"""

try:
   smtpObj = smtplib.SMTP('localhost')
   smtpObj.sendmail(sender, receivers, message)         
   print("Successfully sent email")
except SMTPException:
   print("Error: unable to send email")

代码余额http://www.tutorialspoint.com/python/python_sending_email.htm

答案 2 :(得分:0)

SMTP是一个很棒的模块,但不是那么用户友好。

yagmail试图让它变得更容易一些。

在你的情况下,我会使用:

import yagmail

yag = yagmail.Connect('username', 'password')

with open("msg.csv", "rb") as csvfile:
    csv_reader = csv.reader(csvfile)
    csv_reader.next()

    for line in csv_reader:
        for name, email, message in line.strip().split(','):
            yag.send(email, subject = name, contents = message)