溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

怎樣為VNPY增加數(shù)據(jù)庫記錄交易數(shù)據(jù)功能

發(fā)布時(shí)間:2021-12-04 15:26:15 來源:億速云 閱讀:250 作者:柒染 欄目:編程語言

本篇文章為大家展示了怎樣為VNPY增加數(shù)據(jù)庫記錄交易數(shù)據(jù)功能,內(nèi)容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細(xì)介紹希望你能有所收獲。

在VNPY中,并沒有提供實(shí)際交易數(shù)據(jù)庫記錄功能,雖然可以通過第三方交易軟件去讀取,但是對于針對單個策略交易效果驗(yàn)證還是不方便,這里說以下為VNPY增加數(shù)據(jù)庫記錄交易數(shù)據(jù)功能。

其實(shí)主要還是調(diào)用VNPY已經(jīng)提供的功能。

1.在vnpy.trader.app.ctaStrategy.ctaBase中增加一個新的數(shù)據(jù)庫。

按照你的習(xí)慣給名字,比如 DEAL_DB_NAME = 'VnTrader_DEAL_Db'

2.在vnpy.trader.app.ctaStrategy.ctaTemplate 中,增加一個新的function.

def insertData(self, dbName, collectionName, data):
    if self.trading:
        self.ctaEngine.insertData(dbName, collectionName, data)

3. 在策略onTrade function中加入下面代碼,用策略名字做collection名字

def onTrade(self, trade):
    # 發(fā)出狀態(tài)更新事件
    """收到成交推送(必須由用戶繼承實(shí)現(xiàn))"""
    # 對于無需做細(xì)粒度委托控制的策略,可以忽略onOrder
    t = trade
    self.insertData(DEAL_DB_NAME,self.name,t)

 在策略代碼中,如果沒有DEAL_DB_NAME的引用會不成功,請?jiān)诓呗灾屑尤胍?/p>

   from vnpy.trader.app.ctaStrategy.ctaBase import DEAL_DB_NAME
或者在

self.insertData(DEAL_DB_NAME,self.name,t)

直接寫死,"DEAL_DB_NAME"

發(fā)現(xiàn)寫入數(shù)據(jù)的交易時(shí)間tradeTime只有時(shí)間,沒有日期,不方便分析。開了下源代碼,修改vnpy.trader.app.ctaStrategy.ctaTemplate 比較簡單。

如果發(fā)現(xiàn)插入數(shù)據(jù)是VtTradeData對象,修改tradeTime

from vnpy.trader.vtObject import VtTradeData
from datetime import datetime
def insertData(self, dbName, collectionName, data):
    if self.trading:
        if isinstance(data,VtTradeData):
            data.tradeTime = datetime.now().strftime('%Y-%m-%d %H:%M:%S')
        self.ctaEngine.insertData(dbName, collectionName, data)

上述內(nèi)容就是怎樣為VNPY增加數(shù)據(jù)庫記錄交易數(shù)據(jù)功能,你們學(xué)到知識或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識儲備,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI