Python实战之自动发送邮件的实现
作者:Ckend 发布时间:2023-10-18 15:09:43
自动发送邮件能应用于许多场景,比如我想要知道股票策略中的股票池是否有实时的更新,这时候如果再拉一遍数据,跑一遍脚本,实在是太浪费时间了。为什么不把这一套流程放到服务器上,然后到点自动运行并发送邮件呢?
类似的应用场景还有很多,不仅仅是在股票策略提醒上,比如定时向某些人发送邮件;网站宕机了,实时发送邮件提醒;网站负载过高,发送邮件提醒......等等。
下面就来讲讲怎么用Python构建一个自动发送邮件的脚本。
1.开启SMTP服务
为了实现自动发送邮件的目的,我们需要在邮箱中开启SMTP服务:
这点很关键,别忘了去开启SMTP,否则邮件是无法发送成功的。然后你还需要点击下面生成授权码,这个授权码才是使用Python发送邮件时的真正密码。
邮箱设定成功后,就可以开始脚本开发了。
2.准备
开始之前,你要确保Python和pip已经成功安装在电脑上,如果没有,可以访问这篇文章:超详细Python安装指南 进行安装。
(可选1) 如果你用Python的目的是数据分析,可以直接安装Anaconda,它内置了Python和pip.
(可选2) 此外,推荐大家用VSCode编辑器,它有许多的优点
请选择以下任一种方式输入命令安装依赖:
1. Windows 环境 打开 Cmd (开始-运行-CMD)。
2. MacOS 环境 打开 Terminal (command+空格输入Terminal)。
3. 如果你用的是 VSCode编辑器 或 Pycharm,可以直接使用界面下方的Terminal.
pip install yagmail
看到 Successfully installed xxx 则说明安装成功。本文全部源代码可在后台回复:自动发送邮件 获得。
3.编写脚本
今天需要用到的模块是yagmail,一个非常方便的Python邮件发送模块,用这个模块,你甚至能一行命令发送邮件:
yag = yagmail.SMTP(
host='smtp.qq.com', user='你的邮箱',
password='你的鉴权码', smtp_ssl=True
).send(["发送对象"], "主题", "内容")
为了让这个发送邮件的方法更加具备可用性,我们将其封装到一个类中:
import time
import yagmail
class Mail:
"""
邮件相关类
"""
def sendmail(self, msg, title, receivers):
"""
发送邮件
Arguments:
msg {str} -- 邮件正文
title {str} -- 邮件标题
receivers {list} -- 邮件接收者,数组
"""
yag = yagmail.SMTP(
host='smtp.qq.com', user='你的邮箱',
password='你的鉴权码', smtp_ssl=True
)
try:
yag.send(receivers, title, msg)
print("邮件发送成功")
except BaseException as e:
print(e)
print("Error: 无法发送邮件")
这个类里还可以封装很多其他东西,比如log函数,用于显示时间:
import time
import yagmail
class Mail:
"""
邮件相关类
"""
def log(self, content):
now_time = time.strftime(
"%Y-%m-%d %H:%M:%S", time.localtime()
)
print(f'{now_time}: {content}')
这样,需要显示时间的时候只需要调用self.log即可,优化后的完整代码如下:
import time
import yagmail
class Mail:
"""
邮件相关类
"""
def log(self, content):
now_time = time.strftime(
"%Y-%m-%d %H:%M:%S", time.localtime()
)
print(f'{now_time}: {content}')
def sendmail(self, msg, title, receivers):
"""
发送邮件
Arguments:
msg {str} -- 邮件正文
title {str} -- 邮件标题
receivers {list} -- 邮件接收者,数组
"""
yag = yagmail.SMTP(
host='smtp.qq.com', user='你的邮箱',
password='你的鉴权码', smtp_ssl=True
)
try:
yag.send(receivers, title, msg)
self.log("邮件发送成功")
except BaseException as e:
print (e)
self.log("Error: 无法发送邮件")
发送成功时显示:
# PS D:\CODE\stock\api> python .\sendmail_yagmail.py
2021-06-21 00:00:00: 邮件发送成功
4.小例子
将刚刚编写完的类保存为sendmail.py,接下来就可以尝试一个小例子。我们用一个自动监控网站是否宕机的小脚本做示例:
import time
import requests
from sendmail import Mail
while True:
response = requests.get('https://pythondict.com')
# 根据状态码判断网站是否正常
if response.status_code != 200:
Mail().sendmail(
'哥, pythondict挂了', 'Python实用宝典网站异常监控', ['你的邮箱']
)
time.sleep(600)
通过 requests.get 请求网站,使用 response.status_code 得到状态码,200 为正常,其他情况均为异常。这个检测每十分钟运行一次,因此 time.sleep(600) .
就这样,我们构建起了一个非常简单的网站异常监控脚本,如果你真的要在服务器上运行这个脚本,请记得使用 nohup 让其在后台运行:
nohup python test.py &
来源:https://mp.weixin.qq.com/s/kHxVx3l4ysRqqlTqnfY5Xw


猜你喜欢
- 这是一个access较为豪华的包装范例,他调用了flash的流媒体控件,利用flash的交互与通信功能,借以达到了我们装扮软件的目的。fla
- 微信的小程序是一个很不错的体验,简单,上手快,这几天也在学习使用小程序,自己总结了三种用 Python 作为小程序后端的方式,供你参考。方法
- mysql字符串格式化今天有一个需求,mysql查询返回的格式为:80% ,而数据库中存储的是0.89的格式sql写法如下:select C
- 元组的特点:是一种不可变序列,一旦创建就不能修改1、拆包将元组的元素取出赋值给不同变量>>> a = ('hell
- 下面这个例子描述的是在Godaddy-Linux托管帐户上使用JSP连接到某个MySQL数据库。 <%@ page
- 版本Sublime Text v4.0(4143) 所需软件Sublime Text v4.0(4143)下载地址:https://www.
- 本文实例讲述了JS+CSS模拟可以无刷新显示内容的留言板功能。分享给大家供大家参考。具体实现方法如下:<!DOCTYPE html P
- Console 对象提供对浏览器控制台的接入(如:Firefox 的 Web Console)。不同浏览器上它的工作方式是不一样的,但这里会
- python爬虫是程序员们一定会掌握的知识,练习python爬虫时,很多人会选择爬取微博练手。python爬虫微博根据微博存在于不同媒介上,
- 我也一一试过,结果是:中文乱码问题没解决,mysql服务却不能启动了, 汗颜了,还是自己动手解决吧,我这里也截图了,方便参观。我用的是app
- SQL Server与Oracle、DB2的优劣对比:1.开放性:SQL Server只能在Windows上运行,没有丝毫的开放性,操作系统
- 下面是一个实战项目的结果。 #coding: utf-8 import Image,ImageDraw,ImageFont,os,strin
- 在将自定义的网络权重加载到网络中时,报错:AttributeError: 'dict' object has no attr
- 开发环境说明:Python 35Pytorch 0.2CPU/GPU均可1、LSTM简介人类在进行学习时,往往不总是零开始,学习物理你会有数
- 在python开发的过程中,经常会遇到需要打印各种信息。海量的信息堆砌在控制台中,就会导致信息都混在一起,降低了重要信息的可读性。这时候,如
- 一、柱形图介绍(1)介绍柱状图(Histogram),也称条图(英文:bargraph)、长条图(英文:barchart)、条状图(Bar
- 本文实例讲述了Python实现链表反转的方法。分享给大家供大家参考,具体如下:Python实现链表反转链表反转(while迭代实现):链表的
- 一、使用多个setting文件 开发Django项目是最常见,也是最麻烦的一个问题就是如何区分开发配置与线上配置。有一些解决方案是
- 环境:winxp sp2 ,mysql5.0.18,mysql odbc 3.51 driver 表采用 myisam引擎。access 2
- 元组的结构在这一小节当中主要介绍在 python 当中元组的数据结构:typedef struct { PyObj