gpt4 book ai didi

python - 如何使用 Python 为 Excel 的每一行创建新的 Outlook 电子邮件

转载 作者:太空宇宙 更新时间:2023-11-04 01:52:52 24 4
gpt4 key购买 nike

我正在尝试使用 Excel 工作表来填充 Outlook 电子邮件草稿,并让每一行都创建一封新电子邮件。我正在尝试使用 openpyxl 库来实现这一点。Excel 文件看起来像这样。 Excel Example

我尝试使用列表理解遍历每一行,但结果几乎相同,我收到一封使用第一行数据创建的电子邮件,但未使用其余信息。我现在可以使用这些信息的唯一方法是自己更改 row_offset 数字,但显然这不适用于做很多行。

我使用以下函数从 Excel 文件中获取信息

def get_info():

loc = "Excel_file_location.xlsx"
wb = load_workbook(loc)

info = []
ws = wb[wb.sheetnames[0]]
ws = wb.active

从第 2 行开始获取数据。这里可能有问题吗?

for row in ws.iter_rows(row_offset=1):
for cell in row:
info.append(str(cell.value))
return info

数据=get_info()

带有 Excel 文件数据的电子邮件正文

text = "您好,{1}!工单 #{0} 已完成".format(data[0], data 1 )

创建电子邮件函数

def Emailer(text1, subject, recipient): 将 win32com.client 导入为 win32

outlook = win32.Dispatch('outlook.application')
mail = outlook.CreateItem(0)
mail.To = recipient
mail.Subject = subject
mail.HtmlBody = text1
mail.Display(False)

然后我会使用类似的东西调用 Emailer 函数

Emailer(text, "Completed WO {0} | {1}".format(data[0], data 1 ), data[2])

但我对如何让这个函数对 Excel 工作表的每一行单独工作感到困惑。截至目前,它只会一遍又一遍地编写相同的电子邮件,而不会阅读其余行。

最佳答案

我的建议是将每一行包装到一个对象中,然后将对象推送到列表 info 中,如下所示:

class Recipient():
def __init__(self, w_order, name, email):
self.w_order = w_order
self.name = name
self.email = email


def get_info():

loc = "Excel_file_location.xlsx"
wb = load_workbook(loc)

info = []
ws = wb[wb.sheetnames[0]]
ws = wb.active

for row in range(2, 5):
rec = Recipient("", "", "")
for col in range(ord('A'), ord('D')):
if chr(col) == 'A':
rec.w_order = ws[chr(col) + str(row)].value
elif chr(col) == 'B':
rec.name = ws[chr(col) + str(row)].value
elif chr(col) == 'C':
rec.email = ws[chr(col) + str(row)].value

info.append(rec)


return info

从那里开始,您可以像这样循环访问来自邮件函数中的 get_info() 的信息:

def Emailer(text1, subject, recipient): 

import win32com.client as win3

outlook = win32.Dispatch('outlook.application')
mail = outlook.CreateItem(0)
mail.To = recipient
mail.Subject = subject
mail.HtmlBody = text1
mail.Display(False)

data = get_info()


for i in range(0, len(data)):
Emailer(text, "Completed WO {0} | {1}".format(data[i].w_order, data[i].name), data[i].email)

关于python - 如何使用 Python 为 Excel 的每一行创建新的 Outlook 电子邮件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57598402/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com