python 量化交易,将处理完的数据,自动发送至邮箱——量化03
off999 2024-12-13 15:36 17 浏览 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中非常有用的库
相关推荐
- Linux 网络协议栈_linux网络协议栈
-
前言;更多学习资料(包含视频、技术学习路线图谱、文档等)后台私信《资料》免费领取技术点包含了C/C++,Linux,Nginx,ZeroMQ,MySQL,Redis,fastdfs,MongoDB,Z...
- 揭秘 BPF map 前生今世_bpfdm
-
1.前言众所周知,map可用于内核BPF程序和用户应用程序之间实现双向的数据交换,为BPF技术中的重要基础数据结构。在BPF程序中可以通过声明structbpf_map_def...
- 教你简单 提取fmpeg 视频,音频,字幕 方法
-
ffmpeg提取视频,音频,字幕方法(HowtoExtractVideo,Audio,SubtitlefromOriginalVideo?)1.提取视频(ExtractVi...
- Linux内核原理到代码详解《内核视频教程》
-
Linux内核原理-进程入门进程进程不仅仅是一段可执行程序的代码,通常进程还包括其他资源,比如打开的文件,挂起的信号,内核内部的数据结构,处理器状态,内存地址空间,或多个执行线程,存放全局变量的数据段...
- Linux C Socket UDP编程详解及实例分享
-
1、UDP网络编程主要流程UDP协议的程序设计框架,客户端和服务器之间的差别在于服务器必须使用bind()函数来绑定侦听的本地UDP端口,而客户端则可以不进行绑定,直接发送到服务器地址的某个端口地址。...
- libevent源码分析之bufferevent使用详解
-
libevent的bufferevent在event的基础上自己维护了一个buffer,这样的话,就不需要再自己管理一个buffer了。先看看structbufferevent这个结构体struct...
- 一次解决Linux内核内存泄漏实战全过程
-
什么是内存泄漏:程序向系统申请内存,使用完不需要之后,不释放内存还给系统回收,造成申请的内存被浪费.发现系统中内存使用量随着时间的流逝,消耗的越来越多,例如下图所示:接下来的排查思路是:1.监控系统中...
- 彻底搞清楚内存泄漏的原因,如何避免内存泄漏,如何定位内存泄漏
-
作为C/C++开发人员,内存泄漏是最容易遇到的问题之一,这是由C/C++语言的特性引起的。C/C++语言与其他语言不同,需要开发者去申请和释放内存,即需要开发者去管理内存,如果内存使用不当,就容易造成...
- linux网络编程常见API详解_linux网络编程视频教程
-
Linux网络编程API函数初步剖析今天我们来分析一下前几篇博文中提到的网络编程中几个核心的API,探究一下当我们调用每个API时,内核中具体做了哪些准备和初始化工作。1、socket(family...
- Linux下C++访问web—使用libcurl库调用http接口发送解析json数据
-
一、背景这两天由于一些原因研究了研究如何在客户端C++代码中调用web服务端接口,需要访问url,并传入json数据,拿到返回值,并解析。 现在的情形是远程服务端的接口参数和返回类型都是json的字符...
- 平衡感知调节:“系统如人” 视角下的架构设计与业务稳定之道
-
在今天这个到处都是数字化的时代,系统可不是一堆冷冰冰的代码。它就像一个活生生的“数字人”,没了它,业务根本转不起来。总说“技术要为业务服务”,但实际操作起来问题不少:系统怎么才能快速响应业务需求?...
- 谈谈分布式文件系统下的本地缓存_什么是分布式文件存储
-
在分布式文件系统中,为了提高系统的性能,常常会引入不同类型的缓存存储系统(算法优化所带来的的效果可能远远不如缓存带来的优化效果)。在软件中缓存存储系统一般可分为了两类:一、分布式缓存,例如:Memca...
- 进程间通信之信号量semaphore--linux内核剖析
-
什么是信号量信号量的使用主要是用来保护共享资源,使得资源在一个时刻只有一个进程(线程)所拥有。信号量的值为正的时候,说明它空闲。所测试的线程可以锁定而使用它。若为0,说明它被占用,测试的线程要进入睡眠...
- Qt编写推流程序/支持webrtc265/从此不用再转码/打开新世界的大门
-
一、前言在推流领域,尤其是监控行业,现在主流设备基本上都是265格式的视频流,想要在网页上直接显示监控流,之前的方案是,要么转成hls,要么魔改支持265格式的flv,要么265转成264,如果要追求...
- 30 分钟搞定 SpringBoot 视频推拉流!实战避坑指南
-
30分钟搞定SpringBoot视频推拉流!实战避坑指南在音视频开发领域,SpringBoot凭借其快速开发特性,成为很多开发者实现视频推拉流功能的首选框架。但实际开发中,从环境搭建到流处理优...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- 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)