资源加载中... loading...

交易终端

发明者量化交易平台提供模块化、定制化的交易终端页面。可以自由添加各种数据模块、交易功能模块,甚至可以自己编写代码开发模块(交易终端插件)。 凭借着高度灵活、自由的使用方式也极大方便了手动交易、半程序化交易的用户。交易终端页面上的各种模块均可以拖动、缩放,可以修改模块绑定的交易对、交易所等设置,可以添加多个同类型的模块。

发明者量化交易平台完善了交易终端功能、更好的方便手动交易,推出了交易终端的交易插件功能。

插件原理

原理和调试工具相同,发送一段代码到交易终端页面选定的托管者执行,并且支持返回图表和表格(调试工具目前也升级支持)。 和调试工具功能相同只能执行3分钟,该功能不计费。可以实现一些简单的小功能用于辅助手动交易,复杂的策略还是需要运行实盘。

插件编写

创建交易终端插件,可以在新建策略页面设置策略类型为:「交易插件」。 交易插件支持JavaScriptPythonC++My语言

插件用途

插件可以执行代码一段时间,可执行一些简单的操作。例如冰山委托、挂单、撤单、计算等任务,和调试工具一样使用return返回结果,也可以直接返回图表和表格。 下面举几个例子,其他功能可以自行探索。

  • 返回深度的快照
  // 返回深度的快照
  function main() {
      var tbl = { 
          type: 'table', 
          title: '深度快照 @ ' + _D(), 
          cols: ['#', 'Amount', 'Ask', 'Bid', 'Amount'], 
          rows: []
      }
      var d = exchange.GetDepth()
      for (var i = 0; i < Math.min(Math.min(d.Asks.length, d.Bids.length), 15); i++) {
          tbl.rows.push([i, d.Asks[i].Amount, d.Asks[i].Price+'#ff0000', d.Bids[i].Price+'#0000ff', d.Bids[i].Amount])
      }
      return tbl
  }
  def main():
      tbl = {
          "type": "table",
          "title": "深度快照 @ " + _D(),
          "cols": ["#", "Amount", "Ask", "Bid", "Amount"],
          "rows": []
      }
      d = exchange.GetDepth()
      for i in range(min(min(len(d["Asks"]), len(d["Bids"])), 15)):
          tbl["rows"].append([i, d["Asks"][i]["Amount"], str(d["Asks"][i]["Price"]) + "#FF0000", str(d["Bids"][i]["Price"]) + "#0000FF", d["Bids"][i]["Amount"]])
      return tbl
  void main() {
      json tbl = R"({
          "type": "table",
          "title": "abc",
          "cols": ["#", "Amount", "Ask", "Bid", "Amount"],
          "rows": []   
      })"_json;
      
      tbl["title"] = "深度快照 @" + _D(); 
      auto d = exchange.GetDepth();
      for(int i = 0; i < 5; i++) {
          tbl["rows"].push_back({format("%d", i), format("%f", d.Asks[i].Amount), format("%f #FF0000", d.Asks[i].Price), format("%f #0000FF", d.Bids[i].Price), format("%f", d.Bids[i].Amount)});
      }
      
      LogStatus("`" + tbl.dump() + "`");
      // C++ 不支持return json 显示表格,可以创建实盘显示状态栏表格
  }
  • 画跨期差价
  // 画跨期差价
  var chart = { 
      __isStock: true,    
      title : { text : '差价分析图'},                     
      xAxis: { type: 'datetime'},                 
      yAxis : {                                        
          title: {text: '差价'},                   
          opposite: false                   
      },
      series : [                    
          {name : "diff", data : []}
      ]
  }  
  
  function main() {
      exchange.SetContractType('quarter')
      var recordsA = exchange.GetRecords(PERIOD_M5)
      exchange.SetContractType('this_week')
      var recordsB = exchange.GetRecords(PERIOD_M5)
      
      for(var i = 0; i < Math.min(recordsA.length, recordsB.length); i++){
          var diff = recordsA[recordsA.length - Math.min(recordsA.length, recordsB.length) + i].Close - recordsB[recordsB.length - Math.min(recordsA.length, recordsB.length) + i].Close
          chart.series[0].data.push([recordsA[recordsA.length - Math.min(recordsA.length, recordsB.length) + i].Time, diff])
      }
      return chart
  }
  chart = {
      "__isStock": True,
      "title": {"text": "差价分析图"},
      "xAxis": {"type": "datetime"},
      "yAxis": {
          "title": {"text": "差价"}, 
          "opposite": False
      }, 
      "series": [
          {"name": "diff", "data": []}
      ]
  }  
  
  def main():
      exchange.SetContractType("quarter")
      recordsA = exchange.GetRecords(PERIOD_M5)
      exchange.SetContractType("this_week")
      recordsB = exchange.GetRecords(PERIOD_M5)  
  
      for i in range(min(len(recordsA), len(recordsB))):
          diff = recordsA[len(recordsA) - min(len(recordsA), len(recordsB)) + i].Close - recordsB[len(recordsB) - min(len(recordsA), len(recordsB)) + i].Close
          chart["series"][0]["data"].append([recordsA[len(recordsA) - min(len(recordsA), len(recordsB)) + i]["Time"], diff])
      return chart
  // C++ 不支持 return json 结构画图

策略广场中还有其它范例可以参考,例如:逐笔小量买入/卖出。

使用方式

  • 添加交易终端插件模块 在交易终端页面打开模块添加菜单,当前FMZ账号策略库中的交易终端插件会自动在列表中显示,找到需要添加的插件点击添加。
  • 运行插件 点击「执行」,交易终端插件就开始运行。插件不会显示出日志,但是可以返回显示表格。
  • 插件运行时间 交易终端插件运行时长最长为3分钟,超过3分钟自动停止运行。
扩展API接口 数据探索