概述🌱
記住日期是有點(diǎn)困難,但我們是程序員,使困難的事情更容易是我們唯一的工作,所以我們不記得日期為什么不自動(dòng)化這個(gè)任務(wù)。在這篇文章中,我們將自動(dòng)的生日祝福,是的,正是我們的程序?qū)z查是否有任何生日今天,然后郵寄你的朋友一個(gè)美麗的愿望。
注意:我強(qiáng)烈建議你記住約會(huì),因?yàn)槿绻笥阎肋@件事,他們會(huì)生氣的。
開(kāi)始🌱
1. 設(shè)置:
因此,首先,在前往編寫(xiě)代碼之前,我們需要?jiǎng)?chuàng)建一個(gè)_csv_文件來(lái)存儲(chǔ)有關(guān)我們最親愛(ài)的朋友的信息,如他們的電子郵件地址、姓名、出生日。將該文件命名為 .birthdays.csv
csv 代表"逗號(hào)分離值",它基本上是一種文件類(lèi)型,其中您存儲(chǔ)由逗號(hào)分離的數(shù)據(jù),第一行表示每個(gè)值的標(biāo)題。就像電子表格第一行表示標(biāo)題,然后在每個(gè)標(biāo)題下面,我們寫(xiě)它的價(jià)值由逗號(hào)分開(kāi)。
下面是我們csv文件的示例。

現(xiàn)在我們有一個(gè)文件,其中包含我們的朋友的所有需要的數(shù)據(jù),是時(shí)候創(chuàng)建一些真正有創(chuàng)意的愿望。我們將創(chuàng)建存儲(chǔ)我們朋友愿望的文件。.txt
下面是我們正在做的例子…

python代碼將把[name],替換成男孩/女孩真實(shí)的年紀(jì)
建議您創(chuàng)建多個(gè)祝福模板
把你的生日祝福文件設(shè)置為letter_1.txt,letter_2.txt,并把這些文件保存在letters目錄
現(xiàn)在我們有一個(gè)文件夾,其中包含我們美好的愿望和csv文件。是時(shí)候?qū)懳覀兊?Python 代碼了。
2. 真正的喧囂開(kāi)始
現(xiàn)在打開(kāi)您最喜愛(ài)的代碼編輯器,創(chuàng)建一個(gè)文件并開(kāi)始編碼。。。main.py
正如在前提條件中提到的,我假設(shè)你過(guò)去曾與python一起工作,對(duì)語(yǔ)法感到舒適。
以下是我們將在本項(xiàng)目中使用的模塊列表
datetime
{查找今天的日期并與記錄匹配}
pandas
{用于管理和過(guò)濾來(lái)自我們的csv文件的數(shù)據(jù)}
random
{從字母中隨機(jī)選擇字母}
smtplib
{用于向朋友發(fā)送郵件}
現(xiàn)在讓我們導(dǎo)入所有模塊到我們的文件main.py
from datetime import datetime # importing datetime class from datetime module
import pandas
import random
import smtplib
my_email = "email@gmail.com"
passw = "your_password"
因?yàn)槲覀兊某绦驅(qū)l(fā)送郵件給朋友,所以它也需要發(fā)件人的郵件地址。
使用您的電子郵件地址,您不希望您的朋友通過(guò)他人的郵件收到生日祝福。
因此,現(xiàn)在向前邁進(jìn),我們需要掌握今天的日期,以便我們可以將其與存儲(chǔ)在csv文件中的數(shù)據(jù)進(jìn)行比較。
today = datetime.now()
在這里,我們從類(lèi)datetime
調(diào)用now()
方法,它會(huì)返回今天的日期時(shí)間,我們正在存儲(chǔ)它在``today`變量。
現(xiàn)在,我們將用pandas
讀取我們的csv文件并將其轉(zhuǎn)換為數(shù)據(jù)框架。
# reading csv file and making it's dataframe
data = pandas.read_csv("birthdays.csv")
# filtering data to check if there's any record that birthdate matches with today's date
bday = data[(data.month == today.month) (data.day == today.day)]
# storing our friend's name having birthday today and email to separate variables, stays empty otherwise
name = bday["name"].tolist()
email = bday["email"].tolist()
# making a list of all the friends having birthdays today
friends = []
for n in range(len(name)):
friends.append(
{
"name": name[n],
"email": email[n]
}
)
現(xiàn)在是時(shí)候從我們創(chuàng)建的信件中隨機(jī)選擇一封發(fā)送愿望的信了。首先,我們要檢查我們的friends
列表是否不是空的,然后我們循環(huán)其每個(gè)項(xiàng)目,并為它們生成字母
# selecting a random integer as letter number from all letters, I assume you have 3.
if not friends:
print("no birthday")
else:
for friend in friends:
num = random.randint(1, 3)
with open(f"letters/letter_{num}.txt") as letter:
lines = letter.readlines()
lines[0].strip()
lines[0] = lines[0].replace("[NAME]", friend["name"]) # replacing [NAME] with friend's name
message = "".join(lines)
現(xiàn)在剩下的唯一部分是發(fā)送郵件與選定的隨機(jī)愿望給我們的朋友。下面是我們?nèi)绾巫龅竭@一點(diǎn),在同一個(gè)循環(huán)
# connecting to gmail's service
with smtplib.SMTP("smtp.gmail.com") as connection:
connection.starttls()
# login with our email and password
connection.login(user=my_email, password=passw)
# sending mail to friend's email address
connection.sendmail(from_addr=my_email, to_addrs=friend["email"], msg=f"Subject: HAPPY BIRTHDAY\n\n{message}")
print(f"message sent to {friend['name']}")
就是這樣,如果你遵循得很好,那么最終你的代碼將看起來(lái)像這樣的東西:
import datetime as dt
import pandas
import random
import smtplib
my_email = "your_email@gmail.com"
passw = "your_password"
data = pandas.read_csv("birthdays.csv")
today = dt.datetime.now()
bday = data[(data.month == today.month) (data.day == today.day)]
name = bday["name"].tolist()
email = bday["email"].tolist()
friends = []
for n in range(len(name)):
friends.append(
{
"name": name[n],
"email": email[n]
}
)
if not friends:
print("no birthday")
else:
for friend in friends:
num = random.randint(1, 3)
with open(f"letters/letter_{num}.txt") as letter:
lines = letter.readlines()
lines[0].strip()
lines[0] = lines[0].replace("[NAME]", friend["name"])
message = "".join(lines)
with smtplib.SMTP("smtp.gmail.com") as connection:
connection.starttls()
connection.login(user=my_email, password=passw)
connection.sendmail(from_addr=my_email, to_addrs=friend["email"], msg=f"Subject: HAPPY BIRTHDAY\n\n{message}")
print(f"message sent to {friend['name']}")
不,還沒(méi)有,是時(shí)候檢查它是否工作。

因?yàn)樵赾sv今天沒(méi)有生日,所以你可以看到控制臺(tái)中的消息no birthdays today
現(xiàn)在,如果我更改csv并將任何出生日期設(shè)置為今天的日期,并在再次運(yùn)行程序后保存它

現(xiàn)在它說(shuō),你也可以檢查郵件來(lái)確認(rèn)它。message sent to {whatever name}

到此這篇關(guān)于教你怎么用Python實(shí)現(xiàn)自動(dòng)生日祝福的文章就介紹到這了,更多相關(guān)Python自動(dòng)生日祝福內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
您可能感興趣的文章:- 十個(gè)Python自動(dòng)化常用操作,即拿即用
- 如何用 Python 子進(jìn)程關(guān)閉 Excel 自動(dòng)化中的彈窗
- python自動(dòng)化之如何利用allure生成測(cè)試報(bào)告
- 教你怎么用Python處理excel實(shí)現(xiàn)自動(dòng)化辦公
- Python+uiautomator2實(shí)現(xiàn)自動(dòng)刷抖音視頻功能
- Python 制作自動(dòng)化翻譯工具
- python實(shí)現(xiàn)百度文庫(kù)自動(dòng)化爬取
- 用python自動(dòng)生成日歷
- python調(diào)用stitcher類(lèi)自動(dòng)實(shí)現(xiàn)多個(gè)圖像拼接融合功能
- python實(shí)現(xiàn)自動(dòng)下載sftp文件
- 使用Python自動(dòng)化Microsoft Excel和Word的操作方法
- python 自動(dòng)刷新網(wǎng)頁(yè)的兩種方法
- 發(fā)工資啦!教你用Python實(shí)現(xiàn)郵箱自動(dòng)群發(fā)工資條