我正在制作一个程序,以便可以轻松地将电子邮件发送到具有独特文件的人员列表,每个收件人都有一个独特的文件。该程序读取 .csv 文件形式的列表,其中包含每个收件人的姓氏、名字、电子邮件地址和各自的附件,使用模板自定义每个电子邮件的收件人姓名,并附加他们的文件。
代码如下所示。我为主题行和电子邮件地址使用了占位符,并隐藏了电子邮件的实际文本,但您应该能够理解。email_data 变量是最初加载包含收件人信息的 .csv 文件的位置。
import csv
import datetime
import sys
import smtplib
import yagmail
import tkinter as tk
from tkinter import filedialog
from tkinter import simpledialog
root = tk.Tk()
root.withdraw()
password = simpledialog.askstring("Password", "Enter password:", show='*')
current_date = datetime.datetime.now()
subject_line = f'xyz {current_date.strftime("%B")} {current_date.year} xyz File'
LNAMES = []
FNAMES = []
EMAILS = []
FILES = []
yag = yagmail.SMTP('xyz@xyx.com', password)
email_data = filedialog.askopenfilename(filetypes=[('.csv', '.csv')],
title='Select the Email Data file')
def send_email():
with open(email_data) as csv_file:
csv_reader = csv.reader(csv_file, delimiter=',')
line_count = 0
for row in csv_reader:
last_name = row[0]
first_name = row[1]
email = row[2]
file = row[3]
LNAMES.append(last_name)
FNAMES.append(first_name)
EMAILS.append(email)
FILES.append(file)
line_count += 1
try:
for first_name, last_name, email, file in zip(FNAMES, LNAMES, EMAILS, FILES):
txt = '...'
yag.send(to=email,
subject=subject_line,
contents=[txt, file])
print("Email(s) sent successfully")
input("Press Enter to exit")
sys.exit(1)
except smtplib.SMTPAuthenticationError:
print("Incorrect Email password entered")
input("Press Enter to exit")
sys.exit(1)
send_email()
我遇到的问题是,如果列出的文件不在工作目录中,则会在电子邮件底部发送一段文本,上面写着“file.xlsx”,而不是实际的附件。如果找不到文件,有没有办法抛出异常,所以电子邮件不仅仅是没有真正的附件发送?