BacktraderCSV 數據饋送開發

  |  

backtrader已經提供了通用 CSV數據提要和一些特定的 CSV數據提要。總結:

  • 通用CSV數據

  • 可視化圖表CSV數據

  • YahooFinanceData(用於在線下載)

  • YahooFinanceCSVData(用於已下載的數據)

  • BacktraderCSVData(內部......用於測試目的,但可以使用)

但即便如此,最終用戶可能希望開發對特定 CSV Data Feed的支持。

通常的座右銘是:“說起來容易做起來難”。實際上,該結構旨在使其變得容易。

腳步:

  • backtrader .CSVDataBase繼承

  • 如果需要,定義任何params

  • start方法中進行任何初始化

  • stop方法中進行任何清理

  • 定義實際工作發生的_loadline方法

    此方法接收一個參數:linetokens。

    顧名思義,這包含根據separator參數拆分當前之後的標記(繼承自基類)

    如果完成工作後有新數據……填寫相應的並返回True

    如果沒有可用的東西,因此解析已經結束:返回False

    如果正在讀取文件的幕後代碼發現沒有更多可以解析,則甚至可能不需要返回False

已經考慮到的事情:

  • 打開文件(或接收類似文件的對象)

  • 如果指示存在,則跳過標題行

  • 標記線條

  • 預加載支持(將整個數據饋送一次加載到內存中)

通常一個例子抵得上一千個需求描述。讓我們使用來自BacktraderCSVData的內部定義的 CSV 解析代碼的簡化版本。這個不需要初始化或清理(例如,這可能是打開一個套接字並稍後關閉它)。

筆記

backtrader數據提要包含通常的行業標準提要,這些提要是要填寫的。即:

  • 約會時間

  • 打開

  • 高的

  • 低的

  • 體積

  • 未平倉合約

如果您的策略/算法或簡單的數據閱讀只需要,例如收盤價,您可以保持其他不變(每次迭代都會在最終用戶代碼有機會做任何事情之前自動用 float('NaN') 值填充它們。

在此示例中,僅支持每日格式:

import itertools
...
import backtrader import bt

class MyCSVData(bt.CSVDataBase):

    def start(self):
        # Nothing to do for this data feed type
        pass

    def stop(self):
        # Nothing to do for this data feed type
        pass

    def _loadline(self, linetokens):
        i = itertools.count(0)

        dttxt = linetokens[next(i)]
        # Format is YYYY-MM-DD
        y = int(dttxt[0:4])
        m = int(dttxt[5:7])
        d = int(dttxt[8:10])

        dt = datetime.datetime(y, m, d)
        dtnum = date2num(dt)

        self.lines.datetime[0] = dtnum
        self.lines.open[0] = float(linetokens[next(i)])
        self.lines.high[0] = float(linetokens[next(i)])
        self.lines.low[0] = float(linetokens[next(i)])
        self.lines.close[0] = float(linetokens[next(i)])
        self.lines.volume[0] = float(linetokens[next(i)])
        self.lines.openinterest[0] = float(linetokens[next(i)])

        return True

該代碼期望所有字段都到位並且可以轉換為浮點數,除了具有固定 YYYY-MM-DD 格式並且可以在不使用datetime.datetime.strptime的情況下進行解析的日期時間。

通過添加幾代碼來解決空值、日期格式解析,可以滿足更複雜的需求。 GenericCSVData就是這樣做的。

買者自負

使用GenericCSVData現有的提要和繼承可以完成很多以支持格式。

讓我們添加對Sierra Chart每日格式(始終以 CSV 格式存儲)的支持。

定義(通過查看“.dly”數據文件之一:

  • 字段:日期、開盤價最高價、最低價收盤價、成交量開盤價

    行業標準和已由GenericCSVData以相同順序支持的那些(這也是行業標準)

  • 分隔符:,

  • 日期格式:YYYY/MM/DD

這些文件的解析器:

class SierraChartCSVData(backtrader.feeds.GenericCSVData):

    params = (('dtformat', '%Y/%m/%d'),)

params定義只是重新定義了基類中的現有參數之一。在這種情況下,只需更改日期的格式字符串。

等等…… Sierra Chart的解析器完成了。

下面是GenericCSVData的參數定義作為提醒:

class GenericCSVData(feed.CSVDataBase):
    params = (
        ('nullvalue', float('NaN')),
        ('dtformat', '%Y-%m-%d %H:%M:%S'),
        ('tmformat', '%H:%M:%S'),

        ('datetime', 0),
        ('time', -1),
        ('open', 1),
        ('high', 2),
        ('low', 3),
        ('close', 4),
        ('volume', 5),
        ('openinterest', 6),
    )

推薦閱讀

相關文章

Backtrader磚塊

Renko Bricks 是呈現價格演變的另一種方式,其中價格比時間發揮更重要的作用。這已在1.9.54.122的1.9.54.122版本中作為過濾器引入Stockcharts 對 Renko Bricks 有很好的參考。

Backtrader對逐筆報價數據重新取樣

backtrader 已經可以從分鐘數據中重新採樣。接受價格變動數據不是問題,只需將 4 個常用欄位(open、 high、 low、 close)設置為價格變動值。 但是傳遞要重新採樣的逐筆報價數據再次生成相同的數據。作為或版本 1.1.11.88,情況已不再如此。

Backtrader改進代碼

時不時地,帶有 backtrader 代碼的示例會在互聯網上彈出。在我看來,有幾個是中國人。最新的一個在這裡: 標題是: backtrader-學習筆記2,這顯然(感謝谷歌)翻譯成 backtrader- 學習筆記2。

BacktraderOCO訂單

Release1.9.34.116 將 OCO (又名One Cancel Others)添加到回溯測試武器庫中。 注意 這僅在回溯測試中實現,並且還沒有針對即時代理的實現 注意 隨版本1.9.36.116更新。盈透證券支援 StopTrail和 StopTrailLimit OCO。

Backtrader 教程:數據饋送 - 開發 - CSV

backtrader已經提供了通用 CSV數據提要和一些特定的 CSV數據提要。

Backtrader遞歸指標

backtrader的最初目標之一是:能夠快速製作指標原型以測試新想法它不一定是一個完美的指標,但能夠快速輕鬆地開發它們確實會有所幫助。為了確認設計是正確的,反向交易者標準庫中的第一個指標是指數移動平均線(又名 EMA),其定義為:遞歸。

Backtrader多數據範例

社區中的幾個主題似乎以如何跟蹤訂單為導向,特別是當幾個data feeds在起作用時,還包括當多個訂單一起工作時,

Backtrader教程:分析儀 - PyFolio

注意 從(至少)2017-07-25pyfolio 開始,API已更改,不再 create_full_tear_sheet 具有 gross_lev 作為命名參數的參數。

Backtrader信號策略

操作 backtrader 也是可能的,而無需編寫策略。雖然這是首選方式,但由於構成機器的對象層次結構,使用信號也是可能的。

Backtrader教程:指標 - ta-lib

即使 backtrader 提供了已經 high 數量的內置指標,並且開發指標主要是定義輸入,輸出和以自然的方式編寫公式的問題,有些人也希望使用TA-LIB。