# 读取一列数据并生成列表郵件收件人 recipients = [] for cell in ws['A']: recipients.append(cell.value) # 读取一列数据并生成列表郵件CC recipients1 = [] for cell in ws['B']: recipients1.append(cell.value) # 使用 Outlook API 发送电子邮件 outlook = win32com.client.Dispatch('Outlook.Application') mail = outlook.CreateItem(0) mail.To = ";".join(recipients) mail.CC = ";".join(recipients1) mail.Subject = '自動報告5 出勤人力'就是這段
时间: 2024-03-20 07:43:52 浏览: 17
这段代码看起来比较简单,可能是在读取 Excel 表格数据时出现了问题。建议你检查一下 Excel 文件中邮件收件人和抄送人这两列的数据是否正确,是否有空值或者其他不符合要求的数据。
你可以在代码前面添加一些调试代码,输出一些变量的值,以便更好地了解程序的执行情况。例如:
```python
# 打开 Excel 文件
wb = openpyxl.load_workbook(r'D:\出勤匯總\郵件.xlsx')
# 选择工作表
ws = wb.active
# 读取一列数据并生成列表郵件收件人
recipients = []
for cell in ws['A']:
recipients.append(cell.value)
print(f"recipients: {recipients}") # 输出收件人列表
# 读取一列数据并生成列表郵件CC
recipients1 = []
for cell in ws['B']:
recipients1.append(cell.value)
print(f"recipients1: {recipients1}") # 输出抄送人列表
# 使用 Outlook API 发送电子邮件
outlook = win32com.client.Dispatch('Outlook.Application')
mail = outlook.CreateItem(0)
mail.To = ";".join(recipients)
mail.CC = ";".join(recipients1)
mail.Subject = '自動報告5 出勤人力'
# 添加图片到正文中
attachment = mail.Attachments.Add(img_path, 6, 0)
html_body = f'<html><body><h2>Dear sir:</h2><p>如下為每日加班管控明細,還請查閲,tks!!!</p><img src="cid:{attachment.FileName}"></body></html>'
mail.HTMLBody = html_body
# 添加附件
mail.Attachments.Add("D:\出勤匯總\SMT部編制人力.xlsm")
# 发送邮件
mail.Send()
```
在代码执行时,这些调试信息会输出到控制台,你可以根据输出的结果判断问题所在。