python 量化交易,将处理完的数据,自动发送至邮箱——量化03
off999 2024-12-13 15:36 30 浏览 0 评论
自动发送邮件代码
import pandas as pd
import smtplib
from email.mime.text import MIMEText
from email.mime.multipart import MIMEMultipart
from email.mime.base import MIMEBase
from email import encoders
from email.header import Header
from email.utils import formataddr
import sqlite3
from datetime import datetime, timedelta, time
# 批量自动化给订阅用户发送邮件
# 查询并提取场内基金网格交易数据表'fund_grid_trading'近20分钟生成的内容,保存为pd
def get_recent_data(table_name):
# 连接数据库
conn = sqlite3.connect(r'D:\wenjian\python\smart\data\my_data.db')
c = conn.cursor()
# 获取当前时间和20分钟前的时间
now = datetime.now()
twenty_minutes_ago = now - timedelta(minutes=20)
# 查询最近20分钟的数据
query = f"SELECT * FROM {table_name} WHERE 时间 BETWEEN ? AND ?"
results = pd.read_sql_query(query, conn, params=(twenty_minutes_ago.strftime('%Y-%m-%d %H:%M'), now.strftime('%Y-%m-%d %H:%M')))
# 关闭数据库连接
conn.close()
return results
def send_email(receiver, table_name, file_path1=None, file_path2=None):
# 邮件发送方的信息
sender = '电子邮箱' # 与下方的SMTP保持一致——smtp_obj = smtplib.SMTP_SSL('smtp.exmail.qq.com', 465)
password = '客户端密码'
# 邮件主题和内容
subject = '微信公众号“余汉波”的订阅邮件'
# 获取当前时间的时间部分
current_time = datetime.now().time()
# 根据条件设置邮件内容
if table_name == 'fund_grid_trading':
content = '场内基金网格交易策略'
elif table_name == 'trade_func':
if time(10, 0) < current_time < time(11, 0):
content = 'A股、港股和场内基金交易策略'
elif time(21, 0) < current_time < time(22, 0):
content = '美股交易策略'
else:
content = '微信公众号“余汉波”的订阅邮件'
else:
content = '微信公众号“余汉波”的订阅邮件'
# 创建邮件对象
message = MIMEMultipart()
message['From'] = formataddr((Header(sender, 'utf-8').encode(), sender))
message['To'] = formataddr((Header(receiver, 'utf-8').encode(), receiver))
message['Subject'] = Header(subject, 'utf-8')
filtered_data = get_recent_data(table_name)
# 检查结果是否为空
if filtered_data.empty:
print('结果为空,不发送邮件')
return
html = filtered_data.to_html(index=False)
# 添加邮件正文
# message.attach(MIMEText(content, 'plain', 'utf-8'))
message.attach(MIMEText(content + html, 'html'))
# 添加附件1
if file_path1 is not None:
with open(file_path1, 'rb') as f:
attachment = MIMEBase('application', 'octet-stream')
attachment.set_payload(f.read())
encoders.encode_base64(attachment)
attachment.add_header('Content-Disposition', 'attachment', filename=('utf-8', '', file_path1.split('\\')[-1]))
message.attach(attachment)
# 添加附件2
if file_path2 is not None:
with open(file_path2, 'rb') as f:
attachment = MIMEBase('application', 'octet-stream')
attachment.set_payload(f.read())
encoders.encode_base64(attachment)
attachment.add_header('Content-Disposition', 'attachment', filename=('utf-8', '', file_path2.split('\\')[-1]))
message.attach(attachment)
# 发送邮件,若切换邮箱需要修改SMTP
try:
smtp_obj = smtplib.SMTP_SSL('smtp.exmail.qq.com', 465)
smtp_obj.login(sender, password)
smtp_obj.sendmail(sender, receiver, message.as_string())
print('邮件发送成功')
except smtplib.SMTPException as e:
print('邮件发送失败:', e)
# 读取excel表格中的邮箱地址,参数有三个,第1个是邮箱的表,第2和第3是附件,可以省略。
def send_emails_from_excel(sheet_name, table_name, file_path1=None, file_path2=None):
# 读取Excel文件
df = pd.read_excel(r'D:\wenjian\python\smart\data\sub_user.xlsx', sheet_name=sheet_name)
# 获取邮箱列数据
emails = df['邮箱']
# 循环发送邮件并打印
for receiver in emails:
send_email(receiver, table_name, file_path1, file_path2)
if __name__ == '__main__':
# print(get_recent_data('fund_grid_trading'))
send_emails_from_excel('一般', 'fund_grid_trading')
代码说明
代码有三个自定义函数:
- get_recent_data(table_name):查询并提取近20分钟生成的内容,保存为 pd,参数为数据库的表名称。
- send_email(receiver, table_name, file_path1=None, file_path2=None):读取 excel 表中的邮箱地址,将函数 get_recent_data(table_name)生成的 pd 转成 html,并发送。参数有 4 个,第一个参数是下面函数的函数,不用理它;第二个参数是数据库的表名称;第三和第四个参数都为增加的附件,若没有附件不用理它,默认为没有。
- send_emails_from_excel(sheet_name, table_name, file_path1=None, file_path2=None):读取excel表格中的邮箱地址,参数有4个,第1个是邮箱的表,第2是数据库表的名称,第3和第4是附件,可以省略。
需修改的代码
- conn = sqlite3.connect(r'D:\wenjian\python\smart\data\my_data.db'):改成你的数据库的路径,进行连接。
- twenty_minutes_ago = now - timedelta(minutes=20):修改发送的条件,比如这里是发送近 20 分钟获取数据的内容。
- sender = '电子邮箱':修改成发件人邮箱地址。
- password = '客户端密码':修改成发件人的客户端密码,注意并不是登陆密码,是 SMTP 客户端上面的密码。
- 根据条件设置邮件内容:这部分是判断数据表的条件,满足不同的条件发送不同的内容,看自己的需求要不要这部分内容。
- smtp_obj = smtplib.SMTP_SSL('smtp.exmail.qq.com', 465):修改邮箱对应的 SMTP 服务器。
- df = pd.read_excel(r'D:\wenjian\python\smart\data\sub_user.xlsx', sheet_name=sheet_name):修改接收方的邮箱,这里是存在放在 excel 中,需要修改路径。
- send_emails_from_excel('一般', 'fund_grid_trading'):修改“一般”的 excel 路径的表,修改 'fund_grid_trading'需要发送数据库数据的表名称。若需发送附件,在括号中直接增加附件的路径,最多支持 2 个附件;若要发送多个附件,需对函数 send_email(receiver, table_name, file_path1=None, file_path2=None)进行增加。
- 上一篇:Python之并发+网络编程
- 下一篇:【rq】一个Python中非常有用的库
相关推荐
- 不知道原机主id密码如何激活
-
答案:如果忘记ID账号和密码,可以尝试以下方法激活手机:1.使用备用邮箱或手机号码:如果您已将备用邮箱或手机号码与您的ID账号绑定,可以使用备用邮箱或手机号码进行身份验证以激活手机。2.联系客服:...
- win10安装需要输入产品密钥(win10安装程序要输入产品密匙)
-
可按照如下方式解决:1.右击桌面左下角的“Windows”按钮,然后点击“命令提示符”项。2.接下来再输入以下命令:slmgr/ipkW269N-WFGWX-YVC9B-4J6C9-T83GX按回...
- 手机秒变电脑摄像头(手机秒变电脑摄像头怎么设置)
-
可以的我用过,但是要你手机支持啊国产的山寨机很多都支持这个功能:支持这个功能的手机摄像头有两种工作状态:手机摄像状态和USB连接状态,在手机设置里把手机的摄像头改为USB连接状态,直接插到电脑上就可以...
- bios没有advanced选项(bios没有advanced选项卡)
-
华硕主板可开机后点击ESC键或F12键选择AdvancedBIOSFeatures项:你说的只很少几项可以修改,可能是分别设置了CMOS密码和开机密码。而你进入COMS时输的的开机密码!要输入C...
- 路由器选购技巧(路由器选购技巧大全)
-
第一,WI-FI协议;我们在购买路由器的时候需要仔细注意分辨WI-FI协议是厂家的噱头还是真正实用的,对上网体验有帮助的功能。目前的Wi-Fi协议已经发展到第6代,既厂商宣传的Wi-Fi...
- win7电脑没有声音怎么解决(win7电脑为什么没声音)
-
1.在我们的win7系统中,突然间没有声音,此时用鼠标右键点击电脑左边的开始菜单,选择“管理”按钮。2.在此页点击系统工具下面的设备管理器,然后展开声音、视频和游戏控制器此选项。3、在该选项当中,...
- playstore(playstore app install english)
-
原文:PlayStore翻译:谷歌的电子市场,或者是指一些虚拟的电子商城。例句:Playstore,restaurant,oricecreamstandtogether.情景游戏...
- office2010不激活可以用吗(window10中office不激活可以吗)
-
可以购买正版授权码激活或激活工具,不激活也可以一直用,但是每一次打开都会弹框。可以使用。因为Office2010不激活后,只会出现一个提醒框,并不影响软件的正常使用。但是未激活的Office2010不...
- 雨林木风在线重装系统(雨林木风系统安装教程win10)
-
一,一般雨林木风番茄花园之类的盗版系统重装系统后都是自动激活的,不需要再重新激活。二,如果偶尔系统提示没有激活的话,上系统之家等网站可以下载激活码,按提示激活即可。三,不建议安装雨林木风之类的盗版系统...
- 系统镜像文件放在哪里(系统镜像文件放在哪里好)
-
镜像文件路径在安装的U盘内有显示,如果没有显示,那是文件不对,或被解压了。镜像文件是一些压缩文件的统称。常见的有img格式的文件(例如,文本文件的格式是txt),它通常是用特定的软件,将本身自带启动文...
- mtu设置多少最好(mtu设置多少最好 4g)
-
路由器MTU的设置应根据网络情况决定,各种网络环境建议使用的MTU值如下:1.1500—以太网信息包最大值,也是默认值,是没有PPPoE和虚拟专用网络的网络连接的典型设置。是大部分路由器,网络适配器和...
- u盘最便宜多少钱一个(u盘最低价格)
-
一般情况下,一分钱,一分货;没有又便宜,货又好的事情。1、扩容盘。扩容盘是用PC技术,在量产时运用容量优先,输入了固定的容量,但它真实的容量只有标称容量的10倍左右。512M没人要的U盘扩容成4G,它...
- 小白三步装机教程(小白三步装机法)
-
下面给大家整理了一份小白装机的详细教程,有需要的朋友们快来看看吧!1、我们下载一个小白软件,然后选择了安装win7系统。2、在下载界面,下载速度取决于您的网络您只需要耐心等待即可。3、软件下载完成后会...
欢迎 你 发表评论:
- 一周热门
-
-
抖音上好看的小姐姐,Python给你都下载了
-
全网最简单易懂!495页Python漫画教程,高清PDF版免费下载
-
飞牛NAS部署TVGate Docker项目,实现内网一键转发、代理、jx
-
Python 3.14 的 UUIDv6/v7/v8 上新,别再用 uuid4 () 啦!
-
python入门到脱坑 输入与输出—str()函数
-
宝塔面板如何添加免费waf防火墙?(宝塔面板开启https)
-
Python三目运算基础与进阶_python三目运算符判断三个变量
-
(新版)Python 分布式爬虫与 JS 逆向进阶实战吾爱分享
-
失业程序员复习python笔记——条件与循环
-
系统u盘安装(win11系统u盘安装)
-
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)
