同時第三方資料來源和資料庫歷史資料,作為cta策略初始化
首先個人推薦使用第三方資料來源,如果資料來源質量有保證的話。
如果啟動第三方資料來源,在cta策略啟動時候,會從資料來源下載load_bar所需要的預期的資料,看策略需求,下載日期或長或短。
如果策略較少沒關係,如果策略較多,尤其是同一合約有多個策略時候,每次啟動就花費非常多時間,而且很多是重複下載,比如如果有多個螺紋鋼策略,就要下載多次螺紋鋼資料,還是不太方法。
這裡思路很簡單,策略啟動時候,對比啟動需要資料是否在資料庫內,如果有使用資料庫資料,如果沒有,下載再使用。
對比是按照需要資料的開始結束和資料庫內bar overview表的開始和結束。查詢結束時候可能大於bar結束時候,比如下午8點半啟動,但是bar結束資料是下午3點;這樣可能有差異取讀取,想想為了安全,冗餘一些沒有關係。
程式碼如下,只要用這個替代cta_engine裡面同名方法即可。這個是基於vntrade 2.3 的,2.6 的版本,改為 query_bar_from_datafeed即可
from vnpy.trader.database import database_manager from tzlocal import get_localzone LOCAL_TZ = get_localzone() def query_bar_from_rq( self, symbol: str, exchange: Exchange, interval: Interval, start: datetime, end: datetime ): """ Query bar data from RQData. """ req = HistoryRequest( symbol=symbol, exchange=exchange, interval=interval, start=start, end=end ) bar_start = None bar_end = None bar_overview_list = database_manager.get_bar_overview() for bar_overview in bar_overview_list: if bar_overview.symbol == symbol and bar_overview.exchange == exchange and bar_overview.interval == interval: bar_start = bar_overview.start.astimezone(LOCAL_TZ) bar_end = bar_overview.end.astimezone(LOCAL_TZ) if bar_start <= start: req = HistoryRequest( symbol=symbol, exchange=exchange, interval=interval, start= bar_end, end=end + timedelta(minutes=1) ) data = rqdata_client.query_history(req) if data: database_manager.save_bar_data(data) if bar_end: self.write_log(f"{symbol}.{exchange}-{interval.value},資料庫已有 {bar_start} 到 {bar_end}資料,從 {bar_end} 到{end}歷史資料下載完成") else: self.write_log( f"{symbol}.{exchange}-{interval.value},從 {start} 到{end}歷史資料下載完成") else: if bar_end: self.write_log(f"{symbol}.{exchange}-{interval.value},資料庫已有 {bar_start} 到 {bar_end}資料,從 {bar_end} 到{end}或無歷史資料") else: self.write_log( f"{symbol}.{exchange}-{interval.value},從 {start} 到{end}歷史資料下載失敗") bars = database_manager.load_bar_data( symbol=symbol, exchange=exchange, interval=interval, start=start, end=end, ) return bars
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/22259926/viewspace-2838063/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 資料庫學習筆記1(資料管理歷史)資料庫筆記
- Jupyter Notebook實現從IB介面歷史資料獲取,寫入資料庫,策略回測和實盤交易資料庫
- 國產資料庫源流史:AntDB資料庫資料庫
- C/C++ Qt 資料庫與Chart實現歷史資料展示C++QT資料庫
- BIRT 怎麼呼叫 Webservice 作為資料來源Web
- 世界資料庫史資料庫
- Spring系列 之資料來源的配置 資料庫 資料來源 連線池的區別Spring資料庫
- 從資料庫發展史看資料庫未來技術趨勢資料庫
- 走進資料的歷史
- 實時資料庫與時序資料庫資料庫
- 明解資料庫------資料庫儲存演變史資料庫
- 「資料庫、資料庫連線池、資料來源」這些概念你真的理解了嗎?資料庫
- 基於多資料來源零程式碼同時生成多個資料庫CRUD增刪改查RESTful API介面資料庫RESTAPI
- 資料庫表初始化資料庫
- PG資料庫初始化資料庫
- Spring-Boot 多資料來源配置+動態資料來源切換+多資料來源事物配置實現主從資料庫儲存分離Springboot資料庫
- 資料庫備份策略資料庫
- zabbix清除歷史監控資料
- 歷史股票資料的爬取
- 【YashanDB資料庫】yasboot查詢資料庫狀態時顯示資料庫狀態為off資料庫boot
- mysql資料庫多表同結構合併資料MySql資料庫
- 時序資料庫InfluxDB之備份和恢復策略資料庫UX
- 時序資料庫 InfluxDB 之備份和恢復策略資料庫UX
- 深度 | 實時歷史資料庫儲存成本驚人,怎麼破?資料庫
- 當查詢的資料來自多個資料來源,有哪些好的分頁策略?
- ABP預設模板修改預設資料庫型別並初始化資料庫資料資料庫型別
- OceanBase 首席架構師:關聯式資料庫到三代分散式資料庫,我親歷的資料庫演進史架構資料庫分散式
- 資料科學的歷史,從洞穴壁畫到大資料資料科學大資料
- 資料庫發展史(上)資料庫
- 資料庫發展史(中)資料庫
- 資料庫發展史(下)資料庫
- 多資料來源與動態資料來源的權衡
- phpMyAdmin管理資料庫和資料表PHP資料庫
- 雲資料建模:為資料倉儲設計資料庫資料庫
- Fabric 1.0原始碼分析(21)Ledger #historydb(歷史資料庫)原始碼資料庫
- 談談資料資產和資料產品的異同
- 資料庫索引選擇策略資料庫索引
- python實現股票歷史資料析Python