每天坚持做逆回购,一年下来,年化收益能达到多少?(附代码)

空口无凭,用数据说话,你可以自己检验各种逆回购策略的历史收益率。

比如说下面这段代码,可以自动进行沪深两市一天期国债逆回购的交易,在收盘之前,或下午 4 点钟之前,自动进行国债逆回购,用闲余资金理财获取收益。

如果你想知道这样交易能不能赚钱,或者每年能赚几个点,别人说的都没用,自己去回测。

如果你认为回测1年、2年,得到的结果难以令人信服,可能包含了偶然因素,

那么通过简单的修改参数,就可以完成回测5年、10年。

如果你也想尝试一下国债逆回购策略回测,

可以直接回复“QMT”, 零门槛获取的量化交易策略终端!!!

# 比较沪深两市的一天期的买一国债逆回购,选择值大的进行卖出
def place_order_based_on_asset(xt_trader, acc, xtdata):# 检查连接结果connect_result = xt_trader.connect()if connect_result == 0:print('连接成功')try:# 查询证券资产asset = xt_trader.query_stock_asset(acc)print("证券资产查询保存成功, 可用资金:", asset.cash)# 判断可用资金是否足够if asset.cash >= 1000:# 根据资产计算订单量order_volume = int(asset.cash / 1000) * 10# 获取市场数据以确定股票代码和价格xtdata.subscribe_quote('131810.SZ', period='tick', start_time='', end_time='', count=1, callback=None)xtdata.subscribe_quote('204001.SH', period='tick', start_time='', end_time='', count=1, callback=None)generate_func = xtdata.get_market_data(field_list=['bidPrice'], stock_list=['131810.SZ','204001.SH'], period='tick', start_time='', end_time='', count=-1, dividend_type='none', fill_data=True)# 提取 '131810.SZ' 和 '204001.SH' 的最后一个 bidPriceprice_131810 = generate_func['131810.SZ']['bidPrice'][-1][0]price_204001 = generate_func['204001.SH']['bidPrice'][-1][0]# 根据价格选择股票代码和价格if price_131810 >= price_204001:stock_code, price = '131810.SZ', price_131810else:stock_code, price = '204001.SH', price_204001# 下达股票订单xt_trader.order_stock(acc, stock_code, xtconstant.STOCK_SELL, order_volume, xtconstant.FIX_PRICE, price, '国债逆回购策略', '')print(f"成功下达订单,股票代码:{stock_code},价格:{price},订单量:{order_volume}。")else:print("可用资金不足,不进行交易")except Exception as e:print("下达订单时出现错误:", e)else:print('连接失败')

当你对简单策略有所了解之后,就可以尝试逻辑复杂一些的策略,并且在基础上进行参数调整,尝试能否带来更高的收益

# encoding:gbk
import logging
from datetime import datetime, timedelta
from decimal import Decimal as D
from decimal import InvalidOperationlogging.basicConfig(level=logging.INFO)# 挂单失败后的等待时长,以秒计
TIMEOUT_ON_FAIL_SEC = 30
# 等待account_callback的时长
# RUN_TIME_DELAY = 30# how is this not defined in package??
MORNING_START = datetime.strptime(datetime.now().strftime('%Y%m%d') + '093000', '%Y%m%d%H%M%S')
MORNING_END = datetime.strptime(datetime.now().strftime('%Y%m%d') + '113000', '%Y%m%d%H%M%S')
NOON_START = datetime.strptime(datetime.now().strftime('%Y%m%d') + '130000', '%Y%m%d%H%M%S')
NOON_END = datetime.strptime(datetime.now().strftime('%Y%m%d') + '153000', '%Y%m%d%H%M%S')# for SH only
TRANS_COST_1D = D('5e-6')
TRANS_COST_LONG = D('1.5e-7')
TRANS_COST_MAX = 100# ORDER LIMITS
SH_UPPER = 1e7
SH_LOWER = 1e5
SZ_UPPER = 1e8
SZ_LOWER = 1e3# ASSET NAME DICT
SH_REV_REPO = {'上交所1天': '204001.SH', '上交所2天': '204002.SH', '上交所3天': '204003.SH','上交所4天': '204004.SH', '上交所7天': '204007.SH', '上交所14天': '204014.SH','上交所28天': '204028.SH', '上交所91天': '204091.SH', '上交所182天': '204182.SH',}SZ_REV_REPO = {'深交所3天': '131800.SZ', '深交所7天': '131801.SZ', '深交所14天': '131802.SZ','深交所28天': '131803.SZ', '深交所91天': '131805.SZ', '深交所182天': '131806.SZ','深交所4天': '131809.SZ', '深交所1天': '131810.SZ', '深交所2天': '131811.SZ',}def init(ContextInfo):ContextInfo.accID = accountContextInfo.set_account(ContextInfo.accID)ContextInfo.use_all_cap = False if ALL_CAP == '否' else True# global trading control, set to False if detected error on user's side# stop() does not halt stratContextInfo.order_control = Falseif not ContextInfo.use_all_cap:try:ContextInfo.dollar_vol = float(D(DOLLAR_VOL))except InvalidOperation:ContextInfo.order_control = Trueraise ValueError('读取资金量失败')else:if DOLLAR_VOL != '':logging.warning('已设定使用全部账户资金,忽略所设置资金量')try:ContextInfo.start_time = datetime.strptime(datetime.now().strftime('%Y%m%d') + str(START_TIME), '%Y%m%d%H%M%S')ContextInfo.asset_name = SH_REV_REPO[ASSET_NAME]except KeyError:ContextInfo.asset_name = SZ_REV_REPO[ASSET_NAME]except ValueError as error:if 'unconverted data remains' in str(error):ContextInfo.order_control = Trueraise ValueError('读取挂单时间失败')if not (MORNING_END > ContextInfo.start_time >= MORNING_START) \and not (NOON_END > ContextInfo.start_time >= NOON_START):ContextInfo.order_control = Trueraise ValueError('挂单时间不在可交易时间内')ContextInfo.can_order = FalseContextInfo.order_done = Falseif not ContextInfo.order_control:ContextInfo.run_time("place_order", "{0}nSecond".format(TIMEOUT_ON_FAIL_SEC),ContextInfo.start_time.strftime('%Y-%m-%d %H:%M:%S'), 'SH')def account_callback(ContextInfo, accountInfo):if not ContextInfo.can_order:ContextInfo.can_order = Trueif ContextInfo.use_all_cap:ContextInfo.dollar_vol = accountInfo.m_dAvailableelse:if ContextInfo.dollar_vol > accountInfo.m_dAvailable:ContextInfo.order_control = Trueraise ValueError('下单额度大于账户可用资金')# check if order satisfies lower limit for each exchangeif ('SH' in ContextInfo.asset_name and ContextInfo.dollar_vol < SH_LOWER) \or ('SZ' in ContextInfo.asset_name and ContextInfo.dollar_vol < SZ_LOWER):ContextInfo.order_control = Trueraise ValueError('下单额度低于交易所最低限额')# checks dollar_vol and rounds the total amountif 'SH' in ContextInfo.asset_name and ContextInfo.dollar_vol % SH_LOWER != 0:ContextInfo.dollar_vol = (ContextInfo.dollar_vol // SH_LOWER) * SH_LOWERlogging.warning('下单额度已规整为:{0}'.format(ContextInfo.dollar_vol))elif 'SZ' in ContextInfo.asset_name and ContextInfo.dollar_vol % SZ_LOWER != 0:ContextInfo.dollar_vol = (ContextInfo.dollar_vol // SZ_LOWER) * SZ_LOWERlogging.warning('下单额度已规整为:{0}'.format(ContextInfo.dollar_vol))'''if 'SH' in ContextInfo.asset_name:num_batch_order = int(ContextInfo.dollar_vol // SH_UPPER)remain_order = ContextInfo.dollar_vol - num_batch_order * SH_UPPERif ContextInfo.asset_name == '204001.SH':transaction_cost = TRANS_COST_MAX * num_batch_order + remain_order * TRANS_COST_1Delse:transaction_cost = TRANS_COST_MAX * num_batch_order + remain_order * TRANS_COST_LONGif transaction_cost + ContextInfo.dollar_vol > accountInfo.m_dAvailable:ContextInfo.order_control = Trueraise ValueError('可用资金不足以垫付交易金额与手续费')'''ContextInfo.remain_vol = ContextInfo.dollar_voldef handlebar(ContextInfo):returndef place_order(ContextInfo):if not ContextInfo.can_order or ContextInfo.order_control:returnif not ContextInfo.order_done:if 'SH' in ContextInfo.asset_name:num_batch_order = int(ContextInfo.remain_vol // SH_UPPER)remain_order = ContextInfo.remain_vol - num_batch_order * SH_UPPERfor _ in range(num_batch_order):order_remark = '国债逆回购:尝试报单{0}元 {1}'.format(SH_UPPER, ContextInfo.asset_name)passorder(24, 1102, ContextInfo.accID, ContextInfo.asset_name, 5, -1, SH_UPPER, order_remark, 1,order_remark, ContextInfo)else:num_batch_order = int(ContextInfo.remain_vol // SZ_UPPER)remain_order = ContextInfo.remain_vol - num_batch_order * SZ_UPPERfor _ in range(num_batch_order):order_remark = '国债逆回购:尝试报单{0}元 {1}'.format(SZ_UPPER, ContextInfo.asset_name)passorder(24, 1102, ContextInfo.accID, ContextInfo.asset_name, 5, -1, SZ_UPPER, order_remark, 1,order_remark, ContextInfo)order_remark = '国债逆回购:尝试报单{0}元 {1}'.format(remain_order, ContextInfo.asset_name)passorder(24, 1102, ContextInfo.accID, ContextInfo.asset_name, 5, -1, remain_order, order_remark, 1,order_remark, ContextInfo)ContextInfo.remain_vol = 0ContextInfo.order_done = Truedef order_callback(ContextInfo, orderInfo):curr_remark = orderInfo.m_strRemarkcurr_status = orderInfo.m_nOrderStatusif '国债逆回购' in curr_remark and ContextInfo.asset_name in curr_remark and curr_status == 57:ContextInfo.order_done = False# up the leftover dollar vol by failed amount# logging.info('reported trade amount:{0}, reported_trade_volume:{1}'.format(orderInfo.m_dTradeAmount, orderInfo.m_nVolumeTotal))# 单张100元ContextInfo.remain_vol += orderInfo.m_nVolumeTotal * 100if '交易时间不合法' in orderInfo.m_strCancelInfo:ContextInfo.order_control = Trueraise ValueError('国债逆回购:未能在交易时间内完成下单,停止报单。余量{0}元未报'.format(ContextInfo.remain_vol))logging.warning('国债逆回购:报单废单,原因:\"{0}\",尝试重报'.format(orderInfo.m_strCancelInfo))elif '国债逆回购' in curr_remark and ContextInfo.asset_name in curr_remark and curr_status == 50:logging.info('国债逆回购:报单{0}元成功'.format(orderInfo.m_nVolumeTotal * 100))return

类似于这个自动逆回购策略:在QMT软件中,相当多成熟策略的代码可以直接用pycharm就可以打开,没有加密的,

说一下开通量化交易的条件,仅需要在券商开户,资金量达到合规门槛既可申请免费使用。佣金费用为万0.854 ETF免5,非常厚道,有更多交易的客制化需求或者想深入了解系统可v❤️联系我:XD1996CD

如果你也想尝试一下国债逆回购策略回测,

可以直接回复“QMT”, 零门槛获取的量化交易策略终端!!!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/802739.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

怎样买国债逆回购最划算,国债逆回购手续费是多少?1折

国债逆回购是一种以国债作为抵押物的贷款&#xff0c;是一种能为投资者提高闲置资金增值能力的金融品种。国债逆回购的优势有&#xff1a; 安全性高&#xff0c;因为国债是信用等级最高、违约风险最低的金融资产&#xff0c;而且国债逆回购是在证券交易所进行的受监管的交易 …

【题解 | 二叉树】给定二叉树的后序遍历和中序遍历,求层序遍历结果

树的遍历 给定一棵二叉树的后序遍历和中序遍历&#xff0c;请你输出其层序遍历的序列。这里假设键值都是互不相等的正整数。 输入格式&#xff1a; 输入第一行给出一个正整数 N ( ≤ 30 ) N(≤30) N(≤30)&#xff0c;是二叉树中结点的个数。第二行给出其后序遍历序列。第三…

grep 和 pgrep

grep 和 pgrep 是两个不同的命令&#xff0c;它们在Linux和类Unix系统中用于搜索文本&#xff0c;但各自的应用场景和功能有所差异。 grep 全称&#xff1a;Global Regular Expression Print 用途&#xff1a;grep 主要用于在文件或者通过管道传递的输出中搜索与指定模式&…

深入探讨udevd:Linux中的设备管理守护进程

Linux操作系统的强大功能之一在于其对硬件的优秀支持。无论是新接入的USB设备还是系统内部的硬件变化&#xff0c;Linux都能够灵活地处理。这得益于udevd—一种设备管理守护进程。在本篇博客中&#xff0c;我们将详细探讨udevd的工作原理、配置和在系统中的重要性。 什么是ude…

深度学习500问——Chapter06: 循环神经网络(RNN)(2)

文章目录 6.4 CNN和RNN的区别 6.5 RNNs与FNNs有什么区别 6.6 RNNs训练和传统ANN训练异同点 6.7 为什么RNN训练的时候Loss波动很大 6.8 标准RNN前向输出流程 6.9 BPTT算法推导 6.9 RNN中为什么会出现梯度消失 6.10 如何解决RNN中的梯度消失问题 6.4 CNN和RNN的区别 类别特点描述…

博客系统实现

一.准备工作 1.创建项目&#xff0c;把前端写好的博客静态页面拷贝到webapp目录中 2.引入依赖&#xff0c;这里主要用到servlet&#xff0c;mysql5.1.47&#xff0c;jacson2.15.0 3.找到右上角的edit configurations->smartTomcat->进行配置 4.数据库设计&#xff1a…

2024年4月9号PMP每日三题含答案

2024年4月9号PMP每日三题含答案 1.在执行一个潜艇现代化项目期间&#xff0c;客户要求安装新的潜望镜。项目经理必须怎么做&#xff1f; A.检查可行性&#xff0c;准备预算&#xff0c;并获得变更请求批准 B.执行实施整体变更控制过程&#xff0c;获得预算批准&#xff0c;并执…

Java8 函数式编程 @FunctionInterface使用示例

FunctionInterface 是一个注解&#xff0c;用在接口上面。 接口内部只能有一个方法。 作用&#xff1a; 将函数作为参数传入其它方法。 背景 看如下代码&#xff0c; 发现send1 send2 send3 方法都有共同的代码用于获取参数&#xff0c;唯一不同的是消息发送逻辑不一样。 那…

吴恩达深度学习 (week1,2)

文章目录 1、神经网络监督学习2、深度学习兴起原因3、深度学习二元分类4、深度学习Logistic 回归5、Logistic 回归损失函数6、深度学习梯度下降法7、深度学习向量法8、Python 中的广播9、上述学习总结10、大作业实现:rocket::rocket:&#xff08;1&#xff09;训练初始数据&…

Matlab进阶绘图第49期—气泡堆叠图

气泡堆叠图是堆叠图与气泡图的组合—在堆叠图每根柱子上方添加大小不同的气泡&#xff0c;用于表示另外一个数据变量&#xff08;如每根柱子各组分的平均值&#xff09;的大小。 本文利用自己制作的BarBubble工具&#xff0c;进行气泡堆叠图的绘制&#xff0c;先来看一下成品效…

代码随想录算法训练营第三十五天| 860.柠檬水找零,406.根据身高重建队列,452. 用最少数量的箭引爆气球

题目与题解 860.柠檬水找零 题目链接&#xff1a;860.柠檬水找零 代码随想录题解&#xff1a;​​​​​​​860.柠檬水找零 视频讲解&#xff1a;贪心算法&#xff0c;看上去复杂&#xff0c;其实逻辑都是固定的&#xff01;LeetCode&#xff1a;860.柠檬水找零_哔哩哔哩_bil…

GET请求和POST请求的区别

最为常见的客户端传递参数方式有两种&#xff1a; GET 请求和 POST 请求底层都是基于 TCP/IP 协议实现的&#xff0c;使用二者中的任意一个&#xff0c;都可以实现客户端和服务器端的双向交互。 浏览器地址栏直接输入&#xff1a;一定是GET请求&#xff1b; 超链接&#xff1a;…

从数据采集到可视化展示Node-Red二次开发4G模块

环境监测正逐步迈入数字化、智能化时代。Node-Red作为一种开源流式编程工具&#xff0c;以其强大的数据处理能力和设备集成便捷性&#xff0c;在构建环境监测数据站中发挥着至关重要的作用。钡铼技术支持Node-Red编程开发&#xff0c;支持BLIoTLink软网关和自定义开发非标协议。…

6. TypeScript的枚举类型

在TypeScript中&#xff0c;枚举&#xff08;Enum&#xff09;是一种特殊的数据类型&#xff0c;它允许为一组数值赋予友好的名字。枚举类型在处理一组相关常量时非常有用&#xff0c;比如状态码、方向、月份等。本文将从多个方面深入探讨TypeScript中枚举类型的使用&#xff0…

为什么 MySQL 采用 B+ 树作为索引?

资料来源 : 小林coding 小林官方网站 : 小林coding (xiaolincoding.com) 「为什么 MySQL 采用 B 树作为索引&#xff1f;」这句话&#xff0c;是不是在面试时经常出现。 要解释这个问题&#xff0c;其实不单单要从数据结构的角度出发&#xff0c;还要考虑磁盘 I/O 操作次数&am…

【javaWeb】EL与JSTL

目录 EL表达式&#xff08;Expression Language&#xff09;EL和JSP脚本的区别语法EL操作符EL运算符注意 EL功能EL访问作用域隐式对象示例1&#xff1a;获得应用上下文示例2&#xff1a;获取Cookie对象 JSTL(JavaServerPages Standard Tag Library)JSTL使用步骤JSTL标签分类使用…

【免费题库】华为OD机试 - 单词重量(Java JS Python C C++)

须知 哈喽,本题库完全免费,收费是为了防止被爬,大家订阅专栏后可以私信联系退款。感谢支持 文章目录 须知题目描述输入描述输出描述用例解题思路:Java代码:JS代码:Python代码:C代码:C++代码:题目描述 每个句子由多个单词组成,句子中的每个单词的长度都可能不一样,…

【六 (3)机器学习-机器学习建模步骤/kaggle房价回归实战】

目录 文章导航一、确定问题和目标&#xff1a;1、业务需求分析&#xff1a;2、问题定义&#xff1a;3、目标设定&#xff1a;4、数据可行性评估&#xff1a;5、资源评估&#xff1a;6、风险评估&#xff1a; 二、数据收集&#xff1a;1、明确数据需求2、选择数据来源3、考虑数据…

SpringCloud Alibaba Seata 处理分布式事务

一、前言 接下来是开展一系列的 SpringCloud 的学习之旅&#xff0c;从传统的模块之间调用&#xff0c;一步步的升级为 SpringCloud 模块之间的调用&#xff0c;此篇文章为第十八篇&#xff0c;即使用 Seata 处理分布式事务。 二、分布式事务问题 当单体应用被拆分成微服务应用…

实现虚拟机Ubuntu与主机Windows之间的复制粘贴

实现步骤 在虚拟机Ubuntu界面&#xff0c;CtrlAltT&#xff0c;新建一个终端 # 卸载已有的工具 sudo apt-get autoremove open-vm-tools# 安装工具open-vm-tools sudo apt-get install open-vm-tools# 安装open-vm-tools-desktop sudo apt-get install open-vm-tools-desk…