奥达
与 Oanda 的集成支持以下两个方面:
- 
现场数据投料 
- 
现场交易 
要求
- 
oandapy安装时使用: pip install git+https://github.com/oanda/oandapy.git
- 
pytz(可选,不推荐)考虑到外汇的全球和全天候性质,选择是在 UTC时间内工作。如果愿意,您仍然可以使用所需的输出时区。
示例代码
来源包含以下内容下的完整样本:
- samples/oandatest/oandatest.py
奥达-商店
存储是实时数据馈送/交易支持的基石,在OandaAPI 与数据馈送和代理需求之间提供了一层自适应。
- 
使用以下方法提供获取代理实例的访问: - OandaStore.getbroker(*args, **kwargs)
- 
提供对 getter数据提要实例的访问 
- 
OandaStore.getedata(\*args, **kwargs)
 在这种情况下, **kwargs中的许多内容与dataname、fromdate、todate、sessionstart、sessionend、timeframe、compression等数据源相同该数据可提供其他参数。检查下面的参考资料。 
强制性参数
为了成功连接到Oanda,以下参数是必需的:
- 
token(默认值:None:API 访问令牌
- 
account(默认值:None:账号 id
这由Oanda提供
无论是连接到练习服务器还是连接到真实服务器,请使用:
- practice(默认值:- False:使用测试环境
必须定期检查账户以获取现金和价值。可通过以下方式控制周期:
- account_tmout(默认值:- 10.0:账户价值刷新周期/现金刷新
奥恩达饲料
实例化数据:
- 
根据 Oanda 指南传递符号 - 欧元/美元兑必须按照 Oanda 的指南规定为EUR_USD。将其实例化为:
 py data = oandastore.getdata(dataname='EUR_USD', ...)
- 欧元/美元兑必须按照 Oanda 的指南规定为
时间管理
除非tz参数(与pytz 兼容的对象)被传递到数据馈送,否则所有时间输出均为上述UTC格式。
回填
反向交易者未向Oanda提出特殊要求。对于小时间段,Oanda在实践服务器上返回的回填长度为500条
OandaBroker-实时交易
使用代理
要使用OandaBroker,必须替换大脑创建的标准代理模拟实例。
使用商店型号(首选):
import backtrader as bt
cerebro = bt.Cerebro()
oandastore = bt.stores.OandaStore()
cerebro.broker = oandastore.getbroker()  # or cerebro.setbroker(...) 
经纪人-初始头寸
代理支持单个参数:
- 
use_positions(默认值:True:连接到代理提供商时,使用现有头寸启动代理。在实例化期间设置为 False以忽略任何现有位置
异议
标准使用方面没有变化。只需使用策略中可用的方法(完整解释请参见Strategy参考)
- 
buy
- 
sell
- 
close
- 
cancel
订单执行类型
Oanda支持backtrader所需的几乎所有订单执行类型,但Close除外。
因此,订单执行类型仅限于:
- 
Order.Market
- 
Order.Limit
- 
Order.Stop
- 
Order.StopLimit(使用停止和上限/下限价格)
- 
Order.StopTrail
- 
括号订单通过使用 takeprofit和stoploss订单成员并创建内部模拟订单来支持。
订单有效期
回溯测试中可用的相同有效性概念(具有valid至buy和sell的有效性概念)可用且具有相同的含义。因此,对于Oanda 订单,将valid参数转换为以下值:
- 
None翻译为良好,直到取消由于未指定有效期,因此订单必须在取消前有效 
- 
datetime/date翻译为良好截止日期
- 
timedelta(x)翻译为截止日期(此处为timedelta(x) != timedelta())这被解释为命令从 now+timedelta(x)开始生效的信号
- 
timedelta() or 0翻译为会话已传递一个值(而不是 None),但该值为空,并被解释为对当前天(会话)有效的订单
通知
标准Order状态将通过notify_order方法通知策略(如果被覆盖)
- 
Submitted-订单已发送至 TWS
- 
Accepted-已下订单
- 
Rejected-用于实际拒绝以及订单创建期间不知道其他状态时
- 
Partial-部分执行已发生
- 
Completed-订单已全部执行
- 
Canceled(或Cancelled)
- 
Expired-订单因到期而取消时
参考
奥恩达商店
类 backtrader.stores.OandaStore()
单例类包装以控制到 Oanda 的连接。
参数:
- 
token(默认值:None:API 访问令牌
- 
account(默认值:None:账号 id
- 
practice(默认值:False:使用测试环境
- 
account_tmout(默认值:10.0:账户价值刷新周期/现金刷新
奥恩达经纪人
类 backtrader.brokers.OandaBroker(**kwargs)
Oanda 的代理实现。
此类将订单/位置从 Oanda 映射到backtrader的内部 API。
参数:
- 
use_positions(默认值:True:连接到代理提供商时,使用现有头寸启动代理。在实例化期间设置为 False以忽略任何现有位置
奥恩达数据
类 backtrader.feeds.OandaData(**kwargs)
Oanda 数据源。
参数:
- 
qcheck(默认为0.5)如果没有接收到数据,以秒为单位的唤醒时间,以便有机会正确地重新采样/重播数据包,并在链上传递通知 
- 
historical(默认为False)如果设置为 True,数据馈送将在第一次下载数据后停止。标准数据馈送参数 fromdate和todate将用作参考。如果请求的持续时间大于 IB 允许的持续时间,则数据馈送将发出多个请求,前提是为数据选择了时间段/压缩。 
- 
backfill_start(默认为True)开始时进行回填。在单个请求中将获取最大可能的历史数据。 
- 
backfill(默认为True)断开/重新连接循环后进行回填。间隙持续时间将用于下载尽可能少的数据量 
- 
backfill_from(默认为None)可以传递一个额外的数据源来进行初始层的回填。一旦数据源耗尽,如果需要,将从 IB 进行回填。理想情况下,这意味着要从已存储的源(如磁盘上的文件)进行回填,但不限于此。 
- 
bidask(默认为True)如果 True,则历史/回填请求将从服务器请求出价/要价如果为 False,则会请求中点
- 
useask(默认为False)如果使用bidask价格中的ask部分,而不是bid的默认使用 
- 
includeFirst(默认为True)通过将参数直接设置到 Oanda API 调用,影响历史/回填请求的 1st条的传递 
- 
reconnect(默认为True)网络连接断开时重新连接 
- 
reconnections(默认为-1)尝试重新连接的次数: -1表示永远
- 
reconntimeout(默认为5.0)重新连接尝试之间等待的时间(秒) 
此数据源仅支持timeframe和compression的映射,这符合 OANDA API 开发人员 Guid 中的定义:
(TimeFrame.Seconds, 5): 'S5',
(TimeFrame.Seconds, 10): 'S10',
(TimeFrame.Seconds, 15): 'S15',
(TimeFrame.Seconds, 30): 'S30',
(TimeFrame.Minutes, 1): 'M1',
(TimeFrame.Minutes, 2): 'M3',
(TimeFrame.Minutes, 3): 'M3',
(TimeFrame.Minutes, 4): 'M4',
(TimeFrame.Minutes, 5): 'M5',
(TimeFrame.Minutes, 10): 'M10',
(TimeFrame.Minutes, 15): 'M15',
(TimeFrame.Minutes, 30): 'M30',
(TimeFrame.Minutes, 60): 'H1',
(TimeFrame.Minutes, 120): 'H2',
(TimeFrame.Minutes, 180): 'H3',
(TimeFrame.Minutes, 240): 'H4',
(TimeFrame.Minutes, 360): 'H6',
(TimeFrame.Minutes, 480): 'H8',
(TimeFrame.Days, 1): 'D',
(TimeFrame.Weeks, 1): 'W',
(TimeFrame.Months, 1): 'M', 
任何其他组合都将被拒绝

