Python应用—实现和改良word邮件合并功能

1.实现目的

邮件合并也有其缺陷,那就是每次合并数据都需操作插入合并域,如果经常需要根据数据生成固定模板word文件,那么就显得很麻烦

显然利用程序固定数据替换模式就极为方便,需要生成文件时可以一键操作

2.代码实现

import os.path
import xlrd
from mailmerge import MailMerge


docx = r'D:\Users\86156\PycharmProjects\pythonProject\邮件合并\1.docx'
xlsx = r'D:\Users\86156\PycharmProjects\pythonProject\邮件合并\1.xlsx'

filepath = os.path.dirname(docx)
workbook = xlrd.open_workbook(xlsx)
worksheet = workbook.sheet_by_index(0)
nrow = worksheet.nrows

for key in range(1, nrow):
    with MailMerge(docx) as doc:
        doc.merge(name=str(worksheet.cell_value(key, 1)),
                  position=str(worksheet.cell_value(key, 2)))

        output = filepath + r'\证明-{}.docx'.format(str(worksheet.cell_value(key, 1)))
        doc.write(output)



workbook = xlrd.open_workbook(xlsx)
worksheet = workbook.sheet_by_index(0)
nrow = worksheet.nrows
list1 = []  # 空列表

fo
  • 8
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
邮件合并是指将一封邮件发送给多个收件人,但是每个收件人看到的邮件内容都不同,通常是根据收件人的信息自动填充邮件内容中的某些字段。 在 Python实现邮件合并功能,可以使用第三方库 `smtplib` 和 `email`。以下是一个简单的邮件合并示例: ```python import smtplib from email.mime.text import MIMEText from email.mime.multipart import MIMEMultipart # 收件人列表 to_list = ['example1@example.com', 'example2@example.com'] # 邮件正文模板,可以用占位符 {} 代替需要填充的内容 template = 'Dear {},\n\nThis is a test email. Best regards,\nYour Name' # 发送邮件的邮箱和密码 sender = 'your_email@example.com' password = 'your_email_password' # SMTP 服务器地址和端口 smtp_server = 'smtp.example.com' smtp_port = 587 # 登录邮箱 server = smtplib.SMTP(smtp_server, smtp_port) server.starttls() server.login(sender, password) # 循环发送邮件 for to_addr in to_list: # 构造邮件正文 message = MIMEMultipart() message['From'] = sender message['To'] = to_addr message['Subject'] = 'Test Email' body = MIMEText(template.format(to_addr.split('@')[0]), 'plain') message.attach(body) # 发送邮件 server.sendmail(sender, to_addr, message.as_string()) # 关闭连接 server.quit() ``` 在上面的代码中,我们首先定义了收件人列表和邮件正文模板。然后,我们使用 `smtplib` 和 `email` 库构造邮件正文,并循环发送邮件给每个收件人。在发送邮件之前,我们需要登录邮箱,并指定 SMTP 服务器的地址和端口。最后,我们关闭连接并退出程序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值