Zipline - 如何将捆绑 DataPortal 传递给 TradeAlgorithm.run()?

Zipline - How to pass bundle DataPortal to TradeAlgorithm.run()?

我正尝试通过调用 zipline.algorithm.TradeAlgorithm 的 运行() 方法来 运行 Zipline 回测:

algo = TradingAlgorithm(initialize= CandlestickStrategy.initialize,
                            handle_data= CandlestickStrategy.handle_data,
                            analyze= CandlestickStrategy.analyze,
                            data=None,
                            bundle='quandl')
results = algo.run()

但我不确定传递什么或如何传递数据参数。我已经摄取了名为 'quandl' 的数据包。根据文档,该参数应该接收一个 DataPortal 实例,但我不知道如何根据我摄取的数据创建其中一个实例。 this/is 这个必要的最好方法是什么?

基本上我的目标是创建一个顶级 'dashboard' 风格 class,它可以 运行 使用不同模块中存在的不同策略进行多次回测。

完整代码(dashboard.py):

import pandas as pd
import matplotlib
import matplotlib.pyplot as plt
import matplotlib.dates as mdates
from mpl_finance import candlestick_ohlc
from datetime import datetime, date, tzinfo, timedelta
from dateutil import parser
import pytz
import numpy as np
import talib
import warnings
import logbook
from logbook import Logger
log = Logger('Algorithm')
from zipline.algorithm import TradingAlgorithm
from zipline.api import order_target_percent, order_target, cancel_order, get_open_orders, get_order, get_datetime, record, symbol
from zipline.data import bundles
from zipline.finance import execution
from CandlestickStrategy import CandlestickStrategy

warnings.filterwarnings("ignore")
warnings.filterwarnings("ignore", message="numpy.dtype size changed")
warnings.filterwarnings("ignore", message="numpy.ufunc size changed")

# Choosing a security and a time horizon
logbook.StderrHandler().push_application()
start = datetime(2014, 9, 1, 0, 0, 0, 0, pytz.utc)
end = datetime(2016, 1, 1, 0, 0, 0, 0, pytz.utc)

#dataPortal = data_portal.DataPortal(asset_finder, trading_calendar, first_trading_day, e
#bundle = bundles.load('quandl',None,start)
algo = TradingAlgorithm(initialize= CandlestickStrategy.initialize,
                            handle_data= CandlestickStrategy.handle_data,
                            analyze= CandlestickStrategy.analyze,
                            data=None,
                            bundle='quandl')
results = algo.run()

CandleStickStrategy.py:

import pandas as pd
import matplotlib
import matplotlib.pyplot as plt
import matplotlib.dates as mdates
from mpl_finance import candlestick_ohlc
from zipline.api import order_target_percent, order_target, cancel_order, get_open_orders, get_order, get_datetime, record, symbol
from zipline.finance import execution
from datetime import datetime, date, tzinfo, timedelta
from dateutil import parser
import pytz
import numpy as np
import talib
import warnings

warnings.filterwarnings("ignore", message="numpy.dtype size changed")
warnings.filterwarnings("ignore", message="numpy.ufunc size changed")

class CandlestickStrategy:

    def initialize(context):
        print "initializing algorythm..."
        context.i = 0
        context.asset = symbol('AAL')

    def handle_data(context, data):

        try:
            trailing_window = data.history(context.asset, ['open','high','low','close'], 28, '1d')
        except:
            return


    def analyze(context=None, results=None):

        print "Analyze"

希望有人能指出我正确的方向。

谢谢

我遇到了同样的问题。当 运行 以这种方式手动设置交易算法时,不会评估 bundle 参数。您需要自己创建数据门户。我手动注册了包并创建了一个 data_portal 到 运行 它:

    bundles.register('yahoo-xetra',
                     csvdir_equities(get_calendar("XETRA"), ["daily"],
                                     '/data/yahoo'),
                     calendar_name='XETRA')

    bundle_data = bundles.load(
        'yahoo-xetra',
    )

    first_trading_day = bundle_data.equity_daily_bar_reader.first_trading_day

    data = DataPortal(
        bundle_data.asset_finder,
        trading_calendar=get_calendar("XETRA"),
        first_trading_day=first_trading_day,
        equity_minute_reader=bundle_data.equity_minute_bar_reader,
        equity_daily_reader=bundle_data.equity_daily_bar_reader,
        adjustment_reader=bundle_data.adjustment_reader,
    )

    Strategy = SimpleAlgorithm(trading_calendar=get_calendar("XETRA"), data_frequency='daily',
                               start=pd.Timestamp('2017-1-1 08:00:00+0200', tz='Europe/Berlin'),
                               end=pd.Timestamp('2018-12-27 08:00:00+0200', tz='Europe/Berlin'),
                               capital_base=10000000,
                               data_portal=data)