高效办公,如何利用Python自动发送邮件

自动发送邮件

我们把报表做出来以后一般都是需要发给别人查看,对于一些每天需要发的报表或者是需要一次发送多份的报表,这个时候可以考虑借助Python来自动发送邮件。

使用邮箱的第一步

一般我们在使用QQ邮箱、163邮箱、126邮箱等这些比较常用的邮箱时,只需要输入账号和密码就可以。但是在使用手机端的企业邮箱的时候,一般都需要配置一下,常规的配置界面如下所示:

就是除了在输入账号密码以外,还需要输入一个服务器链接地址,这个地址每个公司都会不太一样。

一份邮件的组成

下图是outlook中发送一份邮件的界面,主要包含发件人、收件人、抄送人、主题、正文、附件这几部分。这也是一般邮件比较通用的组成部分。

如何发送邮件

在发送邮件之前首先需要与服务器进行连接,在Python中主要利用smtplib模块来建立服务器连接接、服务器断开的工作。

不同邮箱的服务器链接地址不一样,大家根据自己使用的邮箱设置相应的服务器链接。下表为常见邮箱对应的服务器链接:

在与163邮箱服务器进行连接之前,需要先登陆自己的163邮箱进行授权设置,授权码设置如下:

点击设置中的POP3/SMTP/IMAP,勾选SMTP服务,根据提是进行授权码设置,设置授权成功后,在Python中利用授权码进行登陆,而不是你本来的邮箱密码,如果使用本来的邮箱密码登陆,会报错。

连接设置好以后就可以使用账户密码进行登录了,登录成功以后就可以对邮件内容进行编辑,编辑完成以后就可以点击发送了,发送完成后断开服务器链接。

如下展示了发送一份邮件的简短流程代码:

正式发送一份邮件

如下以163邮箱为例,展示了发送一份邮件完整的Python代码:

最后的结果如下图:

关于自动发送邮件还有一些进阶的内容,比如定时发送,正文显示html内容等,大家有兴趣的可以自行上网搜索学习。

批量发送邮件

如果是需要同时发送多份邮件,可以把收件人整理成一个表格进行循环遍历,挨个进行发送。

比如我们现在需要给销售部门好几百销售人员分别发送本月各自的销售任务,在发送邮件的时候主题需要命名成xxx任务明细,在正文中的称呼也需要改成对应的收件人,附件中需要添加各自的任务明细表,而且需要抄送给各自的直属上级。

根据上述的需要,我们整理了如下收件人信息相关的表格df:

只需要写一个for循环去遍历这个df表格中的信息,然后就可以分别发送出去,具体实现代码如下: 

通过运行上面的代码,就可以达到一次性给表格df中的所有人发送邮件的需求。

我们每天都会在 Word,Excel,PPT,邮件,微信里耗费大量的时间。

想象一下,如果早上打开电脑时发现不再有3000封邮件需要处理,晚上下班前不再需要为了给日报周报精心排版而花上半小时的时间。这些省下来的时间可以用来提升自己,让自己在更重要的事情上更具有职场竞争力,这该是多么美好的一件事情啊。

重复琐碎的工作,是每个人或多或少都会遇到的。只需要掌握一点点 Python 就可以用程序去处理这些重复烦人的工作。下面我们可以通过教学视频来进一步来学习。

你可能感兴趣的:(高效办公,如何利用Python自动发送邮件)