python练习项目十——向会员发送会费提醒电子邮件

项目:向会员发送会费提醒电子邮件

背景

假定你一直“自愿”为“强制自愿俱乐部”记录会员会费。这确实是一项枯燥的工作,包括维护一个电子表格,记录每个月谁交了会费,并用电子邮件提醒那些没交的会员。不必你自己查看电子表格,而是向会费超期的会员复制和粘贴相同的电子邮件。你猜对了,让我们编写一个脚本,帮你完成任务。

参考思路

程序要做的事:
① 从Excel 电子表格中读取数据。
② 找出上个月没有交费的所有会员。
③ 找到他们的电子邮件地址,向他们发送针对个人的提醒。

这意味着代码需要做到以下几点:

  • 用openpyxl 模块打开并读取Excel 文档的单元格
  • 创建一个字典,包含会费超期的会员。
  • 调用smtplib.SMTP()、ehlo()、starttls()和login(),登录SMTP 服务器。
  • 针对会费超期的所有会员,调用sendmail()方法,发送针对个人的电子邮件提醒。
    在这里插入图片描述

具体实现

①打开Excel 文件

#! python3
# sendDuesReminders.py - Sends emails based on payment status in spreadsheet.
import openpyxl, smtplib, sys

# 打开duesRecords.xlsx 文件,得到的 Workbook 对象
wb = openpyxl.load_workbook('duesRecords.xlsx') 

# 取得Sheet1
sheet = wb.get_sheet_by_name('Sheet1')

# 有了Worksheet对象,就可以访问行、列和单元格了,将最后一列保存在lastCol中
lastCol = sheet.max_column

# 用行号 1 和 lastCol 访问应该记录着最近月份的单元格。取得该单元格的值,保存在latestMonth中。
latestMonth = sheet.cell(row=1, column=lastCol).value

# TODO: Check each member's payment status.
# TODO: Log in to email account.
# TODO: Send out reminder emails.

②查找所有未付成员
一旦确定了最近一个月的列数(保存在lastCol 中),就可以循环遍历第一行(这是列标题)之后的所有行,看看哪些成员在该月会费的单元格中写着paid。如果会员没有支付,就可以从列1 和2 中分别抓取成员的姓名和电子邮件地址。这些信息将放入unpaidMembers 字典,它记录最近一个月没有交费的所有成员。

#! python3
# sendDuesReminders.py - Sends emails based on payment status 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值