量化交易入门 - 基于迅投QMT量化平台 Xquant接口实现从数据获取、数据加工、策略实现到自动下单基本操作

本文主要是介绍量化交易入门 - 基于迅投QMT量化平台 Xquant接口实现从数据获取、数据加工、策略实现到自动下单基本操作,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本文从实际工作角度,全流程实现一个从数据获取到加工处理、再到实际策略的一个全流程自动化交易过程。

一、数据获取前期准备

1. 打开QMT 的MiniQMT终端并登陆

然后可以用原生python在 vscode或jupyter中编辑自己的策略。

2. 初始化数据接口

from qmtbt import QMTStorestore = QMTStore(mini_qmt_path = r'D:\国金QMT交易端模拟\userdata_mini',xtquant_path=r'..\xtquant_231209a\xtquant', account = '***')

二、获取数据

(一)获取市场板块信息

from xtquant import xtdatasectors = xtdata.get_sector_list()
for i in range(0, len(sectors), 6):print(" ".join(sectors[i:i+6]))

 

结果如下:

(二)获取相应板块的股票代码

# 获取市场所有股票代码

contract = xtdata.get_stock_list_in_sector('沪深A股')

# 获取市场所有股票代码
contract = xtdata.get_stock_list_in_sector('沪深A股') 
display(len(contract))  # 显示目前市场股票数

结果如下:

在系统开发过程中,一定要注意数据的格式,不同的板块,要用规范的名称,否则取不到数据,一个小的失误,会让开发过程拉长。

(三)获取个股历史行情日线数据

需要使用前面建立的store对象,使用_fetch_history方法来获取所需要的数据。

day_K = store._fetch_history(symbol=symbol,period='1d', start_time = start_date, end_time= date_today, dividend_type = "front_ratio")   # 获取K线行情

这里和获取tick的方法一致,只是把period参数,改成了1d.

获取到的数据结构如下:

(四)获取历史tick行情

历史tick数据是开仓交易的重要条件之一,这些数据在量化策略过程中起到非常重要的作用,可以看出,QMT获取历史K线和tick用的是一个接口,减少了开发时调用的难度。

res = store._fetch_history(symbol='300359.SZ',period='tick', start_time = tick_date, end_time = tick_date)    # 获取tick数据

运行结果如下:

(五)获取实时市场行情截面数据(实时tick)

ticks =  xtdata.get_full_tick(stock_list)    # 获取最新的全推实时行情
print(ticks)

出来的数据是这样的:

{'600012.SH': {'timetag': '20240118 15:00:02', 'lastPrice': 11.62, 'open': 11.55, 'high': 11.67, 'low': 11.28, 'lastClose': 11.58, 'amount': 68418100, 'volume': 59498, 'pvolume': 5949799, 'stockStatus': 0, 'openInt': 15, 'settlementPrice': 0, 'lastSettlementPrice': 0, 'askPrice': [11.62, 11.63, 11.65, 11.66, 11.67], 'bidPrice': [11.6, 11.59, 11.55, 11.54, 11.53], 'askVol': [72, 35, 219, 68, 195], 'bidVol': [5, 64, 20, 68, 13]}, '600037.SH': {'timetag': '20240118 15:00:04', 'lastPrice': 7.18, 'open': 7.15, 'high': 7.18, 'low': 6.97, 'lastClose': 7.18, 'amount': 113968800, 'volume': 161050, 'pvolume': 16104962, 'stockStatus': 0, 'openInt': 15, 'settlementPrice': 0, 'lastSettlementPrice': 0, 'askPrice': [7.18, 7.19, 7.2, 7.21, 7.22], 'bidPrice': [7.17, 7.16, 7.15, 7.140000000000001, 7.13], 'askVol': [1325, 278, 337, 96, 198], 'bidVol': [208, 20, 84, 185, 109]}}

我们需要用哪个品种的tick,直接取就行了。

tick = ticks.get('600983.SH')
display(tick)

结果是这样的:

这是个好东西,有了这个,就可以实时根据价格进行各种指标的计算和开仓平仓了。

(六)财务数据的获取

xtdata.download_financial_data(["000008.SZ"], table_list=['Capital'])   # 下载资产负债表数据
a = xtdata.get_financial_data(["000008.SZ"],['Capital']).get("000008.SZ")

获取资产负债表里面的相关数据,其他财务数据可以用类似的先下载,后调用的方法来获取。

报表数据相对较齐全,用于基本面量化或者选股时使用。

三、数据加工

(一)历史K线的加工

...

(二)tick数据的加工

未完待续。。。

这篇关于量化交易入门 - 基于迅投QMT量化平台 Xquant接口实现从数据获取、数据加工、策略实现到自动下单基本操作的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/622145

相关文章

golang版本升级如何实现

《golang版本升级如何实现》:本文主要介绍golang版本升级如何实现问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录golanwww.chinasem.cng版本升级linux上golang版本升级删除golang旧版本安装golang最新版本总结gola

SpringBoot中SM2公钥加密、私钥解密的实现示例详解

《SpringBoot中SM2公钥加密、私钥解密的实现示例详解》本文介绍了如何在SpringBoot项目中实现SM2公钥加密和私钥解密的功能,通过使用Hutool库和BouncyCastle依赖,简化... 目录一、前言1、加密信息(示例)2、加密结果(示例)二、实现代码1、yml文件配置2、创建SM2工具

Mysql实现范围分区表(新增、删除、重组、查看)

《Mysql实现范围分区表(新增、删除、重组、查看)》MySQL分区表的四种类型(范围、哈希、列表、键值),主要介绍了范围分区的创建、查询、添加、删除及重组织操作,具有一定的参考价值,感兴趣的可以了解... 目录一、mysql分区表分类二、范围分区(Range Partitioning1、新建分区表:2、分

MySQL 定时新增分区的实现示例

《MySQL定时新增分区的实现示例》本文主要介绍了通过存储过程和定时任务实现MySQL分区的自动创建,解决大数据量下手动维护的繁琐问题,具有一定的参考价值,感兴趣的可以了解一下... mysql创建好分区之后,有时候会需要自动创建分区。比如,一些表数据量非常大,有些数据是热点数据,按照日期分区MululbU

MySQL 删除数据详解(最新整理)

《MySQL删除数据详解(最新整理)》:本文主要介绍MySQL删除数据的相关知识,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、前言二、mysql 中的三种删除方式1.DELETE语句✅ 基本语法: 示例:2.TRUNCATE语句✅ 基本语

MySQL中查找重复值的实现

《MySQL中查找重复值的实现》查找重复值是一项常见需求,比如在数据清理、数据分析、数据质量检查等场景下,我们常常需要找出表中某列或多列的重复值,具有一定的参考价值,感兴趣的可以了解一下... 目录技术背景实现步骤方法一:使用GROUP BY和HAVING子句方法二:仅返回重复值方法三:返回完整记录方法四:

IDEA中新建/切换Git分支的实现步骤

《IDEA中新建/切换Git分支的实现步骤》本文主要介绍了IDEA中新建/切换Git分支的实现步骤,通过菜单创建新分支并选择是否切换,创建后在Git详情或右键Checkout中切换分支,感兴趣的可以了... 前提:项目已被Git托管1、点击上方栏Git->NewBrancjsh...2、输入新的分支的

从入门到精通MySQL联合查询

《从入门到精通MySQL联合查询》:本文主要介绍从入门到精通MySQL联合查询,本文通过实例代码给大家介绍的非常详细,需要的朋友可以参考下... 目录摘要1. 多表联合查询时mysql内部原理2. 内连接3. 外连接4. 自连接5. 子查询6. 合并查询7. 插入查询结果摘要前面我们学习了数据库设计时要满

Python实现对阿里云OSS对象存储的操作详解

《Python实现对阿里云OSS对象存储的操作详解》这篇文章主要为大家详细介绍了Python实现对阿里云OSS对象存储的操作相关知识,包括连接,上传,下载,列举等功能,感兴趣的小伙伴可以了解下... 目录一、直接使用代码二、详细使用1. 环境准备2. 初始化配置3. bucket配置创建4. 文件上传到os

关于集合与数组转换实现方法

《关于集合与数组转换实现方法》:本文主要介绍关于集合与数组转换实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、Arrays.asList()1.1、方法作用1.2、内部实现1.3、修改元素的影响1.4、注意事项2、list.toArray()2.1、方