期货日数据维护与使用_日数据维护_模块运行演示

本文介绍了如何使用PyQt5在Python环境中,通过DataAPI从优矿网下载最新的期货合约列表,以及按需下载并更新日数据的过程,包括新增合约和需要更新数据的合约的管理。
摘要由CSDN通过智能技术生成

写在前面:

本文默认已经创建了项目,如果不知道如何创建一个空项目的,请参看以下两篇博文

PyQt5将项目搬到一个新的虚拟环境中
https://blog.csdn.net/m0_37967652/article/details/122625280
python_PyQt5开发工具结构基础
https://blog.csdn.net/m0_37967652/article/details/131969032

 

1 打开工具

2  在优矿网下载最新合约列表

 优矿中使用的代码

df = DataAPI.FutuGet(secID=u"",ticker=u"",exchangeCD=u"XSGE",contractStatus="",contractObject=u"",prodID="",field=u"",pandas="1")
df.to_csv('futures_XSGE.csv',encoding='utf-8')

df = DataAPI.FutuGet(secID=u"",ticker=u"",exchangeCD=u"XDCE",contractStatus="",contractObject=u"",prodID="",field=u"",pandas="1")
df.to_csv('futures_XDCE.csv',encoding='utf-8')

df = DataAPI.FutuGet(secID=u"",ticker=u"",exchangeCD=u"XZCE",contractStatus="",contractObject=u"",prodID="",field=u"",pandas="1")
df.to_csv('futures_XZCE.csv',encoding='utf-8')

df = DataAPI.FutuGet(secID=u"",ticker=u"",exchangeCD=u"CCFX",contractStatus="",contractObject=u"",prodID="",field=u"",pandas="1")
df.to_csv('futures_CCFX.csv',encoding='utf-8')

df = DataAPI.FutuGet(secID=u"",ticker=u"",exchangeCD=u"XSIE",contractStatus="",contractObject=u"",prodID="",field=u"",pandas="1")
df.to_csv('futures_XSIE.csv',encoding='utf-8')

点击“运行”,进入“数据”界面,下载数据

将合约列表下载到本地,将合约列表文件放到一个空目录下

 3 在工具中选择合约文件所在目录并执行

点击“选择合约所在目录”,选择合约列表文件所在目录

点击“执行”,工具中现存合约和最新合约进行核对,筛出【新增的合约列表】和【需要更新日数据的合约列表】

 4 在工具中下载【新增的合约列表】和【需要更新日数据的合约列表】

图中new.json,为【新增合约列表】,新增合约列表下载后为new.json

图中20240102.json, 为【需要更新日数据的合约列表】,文件名为工具中这些合约的最新日期,【需要更新日数据的合约列表】的文件可能是1个,也可能是多个

5 在优矿网下载待更新的日数据 

ticker_list = ["fu2501", "lu2501", "sc2501"]
df = DataAPI.MktFutdGet(secID=u"",ticker=ticker_list,tradeDate=u"",beginDate=u"",endDate=u"",exchangeCD="",field=u"",pandas="1")
df.to_csv('daily_20240106_00.csv',encoding='utf-8')

下载【新增合约列表】日数据,新增合约中,beginDate字段为空

ticker_list = ["AP401", "AP403", "AP404", "AP405", ...]
df = DataAPI.MktFutdGet(secID=u"",ticker=ticker_list,tradeDate=u"",beginDate=u"20240103",endDate=u"",exchangeCD="",field=u"",pandas="1")
df.to_csv('daily_20240106_11.csv',encoding='utf-8')

 下载【需要更新日数据的合约列表】,beginDate字段为【需要更新日数据的合约列表】json文件名对应日期的下一日

下载后将日数据文件放入一个空目录 

6 在工具中选择日数据文件所在目录并执行

 

 

 

1 新增合约创建新的日数据csv文件

2 更新合约日数据csv文件,将数据追加到最新

3 将数据插入到 t_last30_daily

4 更新 t_online_symbol 数据,增加新增合约,更新合约的最新日期字段

5  计算主力合约并更新到csv文件中,如果有新增品种,创建csv文件

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值