【迅投qmt系列】2、历史数据获取

2024-04-25 07:04

本文主要是介绍【迅投qmt系列】2、历史数据获取,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、基本思想

在 xtquant 中,历史数据要先下载(download_history_data)到本地的缓存文件中,之后才能获取(get_market_data)使用。
如果确认之前已经下载过,且数据完整,那么后续使用前可以不用再次下载。

2、常用函数

xtdata.download_history_data()		# 下载单个资产的历史数据
xtdata.download_history_data2()		# 下载多个资产(资产代码装在[]中)的历史数据xtdata.get_market_data()			# 从已下载的本地数据中取数据方法1
xtdata.get_market_data_ex()			# 从已下载的本地数据中取数据方法2
xtdata.get_local_data()				# 从本地取已下载的数据

为方便,其中 get_market_data 和 get_market_data_ex 合称 gmd 函数。
以下分别简介各个函数的用法。

2.1、下载资产历史数据到本地缓存文件中

下载资产的历史数据,需要用到 download_history_data 和 download_history_data2,他们的使用方法几乎一样。
download_history_data 的使用方法是:

# download_history_data
xtdata.download_history_data(stock_code='xxxxxx.SH', period='1x', start_time='20230101', end_time='20231115',incrementally=True)		# 是否只下载增量数据
)# download_history_data2
def on_callback(data):print("data call back!")print(data)xtdata.download_history_data2(stock_list=['xxxxxx.SH', 'xxxxxx.SZ'], period='1x', start_time='20230101', end_time='20231115',callback=on_callback,incrementally=True)		# 是否只下载增量数据
)

其中:
1、period 的取值是 :1m、5m、15m、30m、1h、1d、tick。。。 时,能取到指定资产指定周期的行情数据
2、period 的取值是:transactioncount1d、orderflow1m 时,能取到指定资产的资金流向数据、订单流数据等数据(需要权限)
3、period 的取值是:northfinancechange1m,同时资产代价是 ’FFFFFF.SGT’ 或者 [‘FFFFFF.SGT’],能取到北向资金数据(需要权限)。其他可下载数据见官方知识库。
4、start_time、end_time 的格式是 ‘yyyymmddHHMMSS’,当只取日线数据时,可以简化为 ‘yyyymmdd’
5、当 start_time=“”,就是从该资产的历史最早时间开始取,当 end_time=“”,就是取到该资产最新的历史数据(如果取的是日内数据,就按周期取到当时最近的日内数据),两者可以都为 “”…
6、download_history_data2 相对 download_history_data 的改进,除了能批量下载资产的历史数据,还支持回调函数
7、incrementally=True 时,用download_history_data2下载多个资产的历史数据,如果不同资产的最新数据日期不同,download_history_data2能根据各个资产的最新日期补齐数据至end_time
8、使用 token 的模式下,支持下载到指定目录,具体实现后续再展开(坑1)

2.2、从本地获取历史数据

get_market_data、get_market_data_ex、get_local_data 都是从本地数据缓存中获取已经下载的数据,三个函数的使用参数也差不多:

history_data = xtdata.get_market_data(field_list=[],stock_list=etf_list,period=period,start_time=start_date,end_time=end_date,count=-1,dividend_type='none',fill_data=True
)xtdata.get_market_data_ex(field_list=[],# 字段stock_list=[],# 合约代码列表period='1d',# 数据周期——1m、5m、1d、tickstart_time='',# 数据起始时间%Y%m%d或%Y%m%d%H%M%Send_time='',# 数据结束时间%Y%m%d或%Y%m%d%H%M%Scount=-1, # 数据个数。1为只取最新的行情数据,-1为取全部数据dividend_type='none', # 除权方式fill_data=True, # 是否填充数据
)xtdata.get_local_data(field_list=[],# 字段stock_list=[],# 合约代码列表period='1d',# 数据周期——1m、5m、1d、tickstart_time='',# 数据起始时间%Y%m%d或%Y%m%d%H%M%Send_time='',# 数据结束时间%Y%m%d或%Y%m%d%H%M%Scount=-1, # 数据个数。1为只取最新的行情数据,-1为取全部数据dividend_type='none', # 除权方式fill_data=True, # 是否填充数据
)

三者的共同点是,返回的都是 {keys: DataFrames} 格式的数据
三者的区别是:
get_market_data 返回的是两层 dict,第一层 key 是资产代码,第二层 key 是 field_list 中的每个字段,第二层 value 是对应字段的 DataFrame 类型的数据,内容除了本地数据,在订阅之后,也包含有最新的行情数据。
get_market_data_ex 返回的是一层dict,key是 资产代码,value 是包含 field_list 中的所有字段的 DataFrame,内容除了本地数据,在订阅之后,也包含有最新的行情数据。
get_local_data 返回的结果格式与 get_market_data_ex 一样,但是内容只有之前用 download_history_data 下载到本地的数据。

如何同时获取到拼接完整的历史数据和实时行情数据,后续再展开(坑2)。

(内容随时迭代更新中,欢迎常回来看看)

这篇关于【迅投qmt系列】2、历史数据获取的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


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

相关文章

python获取cmd环境变量值的实现代码

《python获取cmd环境变量值的实现代码》:本文主要介绍在Python中获取命令行(cmd)环境变量的值,可以使用标准库中的os模块,需要的朋友可以参考下... 前言全局说明在执行py过程中,总要使用到系统环境变量一、说明1.1 环境:Windows 11 家庭版 24H2 26100.4061

使用Python获取JS加载的数据的多种实现方法

《使用Python获取JS加载的数据的多种实现方法》在当今的互联网时代,网页数据的动态加载已经成为一种常见的技术手段,许多现代网站通过JavaScript(JS)动态加载内容,这使得传统的静态网页爬取... 目录引言一、动态 网页与js加载数据的原理二、python爬取JS加载数据的方法(一)分析网络请求1

通过cmd获取网卡速率的代码

《通过cmd获取网卡速率的代码》今天从群里看到通过bat获取网卡速率两段代码,感觉还不错,学习bat的朋友可以参考一下... 1、本机有线网卡支持的最高速度:%v%@echo off & setlocal enabledelayedexpansionecho 代码开始echo 65001编码获取: >

使用Python实现调用API获取图片存储到本地的方法

《使用Python实现调用API获取图片存储到本地的方法》开发一个自动化工具,用于从JSON数据源中提取图像ID,通过调用指定API获取未经压缩的原始图像文件,并确保下载结果与Postman等工具直接... 目录使用python实现调用API获取图片存储到本地1、项目概述2、核心功能3、环境准备4、代码实现

Python实现获取带合并单元格的表格数据

《Python实现获取带合并单元格的表格数据》由于在日常运维中经常出现一些合并单元格的表格,如果要获取数据比较麻烦,所以本文我们就来聊聊如何使用Python实现获取带合并单元格的表格数据吧... 由于在日常运维中经常出现一些合并单元格的表格,如果要获取数据比较麻烦,现将将封装成类,并通过调用list_exc

通过C#获取Excel单元格的数据类型的方法详解

《通过C#获取Excel单元格的数据类型的方法详解》在处理Excel文件时,了解单元格的数据类型有助于我们正确地解析和处理数据,本文将详细介绍如何使用FreeSpire.XLS来获取Excel单元格的... 目录引言环境配置6种常见数据类型C# 读取单元格数据类型引言在处理 Excel 文件时,了解单元格

Java根据IP地址实现归属地获取

《Java根据IP地址实现归属地获取》Ip2region是一个离线IP地址定位库和IP定位数据管理框架,这篇文章主要为大家详细介绍了Java如何使用Ip2region实现根据IP地址获取归属地,感兴趣... 目录一、使用Ip2region离线获取1、Ip2region简介2、导包3、下编程载xdb文件4、J

SpringBoot整合mybatisPlus实现批量插入并获取ID详解

《SpringBoot整合mybatisPlus实现批量插入并获取ID详解》这篇文章主要为大家详细介绍了SpringBoot如何整合mybatisPlus实现批量插入并获取ID,文中的示例代码讲解详细... 目录【1】saveBATch(一万条数据总耗时:2478ms)【2】集合方式foreach(一万条数

python获取网页表格的多种方法汇总

《python获取网页表格的多种方法汇总》我们在网页上看到很多的表格,如果要获取里面的数据或者转化成其他格式,就需要将表格获取下来并进行整理,在Python中,获取网页表格的方法有多种,下面就跟随小编... 目录1. 使用Pandas的read_html2. 使用BeautifulSoup和pandas3.

SpringBoot UserAgentUtils获取用户浏览器的用法

《SpringBootUserAgentUtils获取用户浏览器的用法》UserAgentUtils是于处理用户代理(User-Agent)字符串的工具类,一般用于解析和处理浏览器、操作系统以及设备... 目录介绍效果图依赖封装客户端工具封装IP工具实体类获取设备信息入库介绍UserAgentUtils