Inventor Quantitative Trading Platform Extension API를 사용하여 TradingView 경고 신호 거래를 구현합니다.
Inventor Quantitative Trading Platform 확장 API는 최근 직접 액세스 모드를 지원하도록 업그레이드되었습니다. 이를 통해 TradingView 알람 신호를 Inventor Quantitative Trading Platform 로봇으로 쉽게 전송하여 자동 거래를 실현할 수 있습니다. 아직도 확장 API가 무엇인지 모르시겠다면 자세히 설명해 드리겠습니다.
Inventor 양적 거래 플랫폼 확장 API
확장 API의 주요 기능은 프로그래밍 방식으로 운영되는 발명가의 양적 거래 플랫폼에서 다양한 기능을 위한 인터페이스를 제공하는 것입니다. 예를 들어, 동시에 로봇을 일괄적으로 시작하고, 예약된 시간에 로봇을 시작 및 중지하고, 로봇 정보 세부 정보를 읽는 등의 기능을 제공합니다. 우리는 Inventor Quantitative Trading Platform Extension API를 사용하여 TradingView 경고 신호 거래를 구현합니다. 이 요구 사항은 API 확장만 필요합니다.CommandRobot(RobotId, Cmd)인터페이스는 지정된 ID를 사용하여 로봇에 대화형 지침을 보낼 수 있습니다. 로봇은 지침을 받은 후 해당 작업(예: 매수 또는 매도 주문)을 수행할 수 있습니다.
확장 API를 사용하려면 먼저 자신의 발명가 계정을 만들어야 합니다.API KEY:

API KEY핵심은access key그리고secret key구성,API KEY이는 프로그램된 운영을 통해 발명된 양적 거래 플랫폼의 핵심이므로 적절히 보관하고 절대로 공개해서는 안 됩니다. FMZ 확장 프로그램 생성API KEY사용 시 권한을 지정할 수 있습니다.API KEY액세스 권한 부여CommandRobot(RobotId, Cmd)이 예에서는 보안상의 이유로 FMZ 확장 프로그램에만 권한을 부여합니다.API KEY부여하다CommandRobot(RobotId, Cmd)인터페이스에 대한 액세스 권한.
확장 API에 대한 직접 액세스 모드
직접 액세스 모드는 다음을 의미합니다.API KEYURL의 쿼리에 직접 쓰세요. 예를 들어, Inventor Quantitative Trading Platform 확장 API에 액세스하는 URL은 다음과 같이 쓸 수 있습니다.
https://www.fmz.com/api/v1?access_key=xxx&secret_key=yyyy&method=CommandRobot&args=[186515,"ok12345"]
안에,https://www.fmz.com/api/v1인터페이스 주소입니다.?이후Query, 매개변수access_key비밀 키는 xxx로 표현되며 (사용 시 자신의 FMZ 계정의 액세스 키를 입력하세요), 매개변수secret_key비밀 키는 yyyy로 표현되며 (사용 시 자신의 계정 secret_key를 입력하세요), 매개변수는 다음과 같습니다.method액세스할 확장 API 인터페이스의 구체적인 이름입니다.args부름을 받다method인터페이스의 매개변수.
우리는 TradingView를 신호 소스로 사용하여 발명가의 양적 거래 플랫폼 로봇에 거래 명령을 전송합니다.CommandRobot이 인터페이스.
TradingView
우선, TradingView Pro 계정이 필요합니다. 알람의 WebHood 기능은 Basic 레벨에서는 사용할 수 없습니다. TradingView에서 차트를 봅니다.
차트에 지표를 추가하고 다른 스크립트 알고리즘도 추가합니다. 여기서 우리는 가장 일반적으로 사용되는 것을 사용합니다MACD표시기를 선택한 다음 K-라인 주기를 1분으로 설정합니다(신호를 더 빨리 트리거하고 시연을 용이하게 하기 위해).
차트를 마우스 오른쪽 버튼으로 클릭하고 팝업 메뉴에서 알림 추가를 선택합니다.
"알림" 팝업창에 설정WebHook이 단계에서는 서둘러 설정할 필요가 없습니다. 먼저 Inventor의 Quantitative Trading Platform에서 신호를 모니터링하는 로봇을 실행해 보겠습니다.
모니터링 신호 주문 로봇
전략 소스 코드:
javascript
// 全局变量
var BUY = "buy" // 注意:现货用的命令
var SELL = "sell" // 现货用的命令
var LONG = "long" // 期货用的命令
var SHORT = "short" // 期货用的命令
var COVER_LONG = "cover_long" // 期货用的命令
var COVER_SHORT = "cover_short" // 期货用的命令
function main() {
// 清空日志,如不需要,可以删除
LogReset(1)
// 设置精度
exchange.SetPrecision(QuotePrecision, BasePrecision)
// 识别期货还是现货
var eType = 0
var eName = exchange.GetName()
var patt = /Futures_/
if (patt.test(eName)) {
Log("添加的交易所为期货交易所:", eName, "#FF0000")
eType = 1
if (Ct == "") {
throw "Ct 合约设置为空"
} else {
Log(exchange.SetContractType(Ct), "设置合约:", Ct, "#FF0000")
}
} else {
Log("添加的交易所为现货交易所:", eName, "#32CD32")
}
var lastMsg = ""
var acc = _C(exchange.GetAccount)
while(true) {
var cmd = GetCommand()
if (cmd) {
// 检测交互命令
lastMsg = "命令:" + cmd + "时间:" + _D()
var arr = cmd.split(":")
if (arr.length != 2) {
Log("cmd信息有误:", cmd, "#FF0000")
continue
}
var action = arr[0]
var amount = parseFloat(arr[1])
if (eType == 0) {
if (action == BUY) {
var buyInfo = IsMarketOrder ? exchange.Buy(-1, amount) : $.Buy(amount)
Log("buyInfo:", buyInfo)
} else if (action == SELL) {
var sellInfo = IsMarketOrder ? exchange.Sell(-1, amount) : $.Sell(amount)
Log("sellInfo:", sellInfo)
} else {
Log("现货交易所不支持!", "#FF0000")
}
} else if (eType == 1) {
var tradeInfo = null
var ticker = _C(exchange.GetTicker)
if (action == LONG) {
exchange.SetDirection("buy")
tradeInfo = IsMarketOrder ? exchange.Buy(-1, amount) : exchange.Buy(ticker.Sell, amount)
} else if (action == SHORT) {
exchange.SetDirection("sell")
tradeInfo = IsMarketOrder ? exchange.Sell(-1, amount) : exchange.Sell(ticker.Buy, amount)
} else if (action == COVER_LONG) {
exchange.SetDirection("closebuy")
tradeInfo = IsMarketOrder ? exchange.Sell(-1, amount) : exchange.Sell(ticker.Buy, amount)
} else if (action == COVER_SHORT) {
exchange.SetDirection("closesell")
tradeInfo = IsMarketOrder ? exchange.Buy(-1, amount) : exchange.Buy(ticker.Sell, amount)
} else {
Log("期货交易所不支持!", "#FF0000")
}
if (tradeInfo) {
Log("tradeInfo:", tradeInfo)
}
} else {
throw "eType error, eType:" + eType
}
acc = _C(exchange.GetAccount)
}
var tbl = {
type : "table",
title : "状态信息",
cols : ["数据"],
rows : []
}
// tbl.rows.push([JSON.stringify(acc)]) // 测试时使用
LogStatus(_D(), eName, "上次接收到的命令:", lastMsg, "\n", "`" + JSON.stringify(tbl) + "`")
Sleep(1000)
}
}
전략 코드는 매우 간단합니다.GetCommand정책 프로그램에 대화형 메시지가 전송될 때 함수의 반환 값은 다음과 같습니다.GetCommand해당 함수는 이 메시지를 반환하고, 전략 프로그램은 메시지 내용에 따라 해당 거래 작업을 수행합니다. 이 전략에는 대화형 기능을 테스트할 수 있는 대화형 버튼이 설정되었습니다. 예를 들어, 이 전략을 실행하고 Inventor Quantitative Trading Platform의 시뮬레이션된 거래소로 로봇을 구성합니다.WexApp。
상호작용 버튼을 클릭하여 로봇이 구매 명령을 받을 수 있는지 테스트해보세요.
로봇이 수신한 명령 문자열은 다음과 같습니다.buy:0.01。
TradingView 알림이 트리거되면 WebHook 요청 URL이 Inventor Quantitative Trading Platform Extension API에 액세스할 수 있도록 해야 합니다.CommandRobot인터페이스를 사용할 때 전달되는 매개변수는 다음과 같습니다.buy:0.01다 그거죠.
TradingView의 WebHook 설정
TradingView로 돌아와서 WebHook의 URL을 입력합니다. 주다access_key、secret_key자신의 매개변수를 입력하세요API KEY。method고정됨, 접근만 하면 됨CommandRobot이 확장된 API 인터페이스는args매개변수는 다음과 같습니다[机器人ID,命令字符串]그림과 같이 로봇 페이지를 통해 로봇 ID를 직접 얻을 수 있습니다.

이번에는 신호가 트리거되도록 하고 0.02 코인을 구매합니다. 명령 문자열은 다음과 같습니다."buy:0.02". 이것으로 WebHook URL이 완성되었습니다. 이 방법은 URL에 신호를 쓰는 것만 지원합니다. TV 전략 자체에서 발행할 수 있는 경고 메시지의 내용을 얻으려면 https://www.fmz.com/api#��를 참조하세요. %B4%E6 %8E%A5%E9%AA%8C%E8%AF%81.
https://www.fmz.com/api/v1?access_key=e3809e173e23004821a9bfb6a468e308&secret_key=45a811e0009d91ad21154e79d4074bc6&method=CommandRobot&args=[191755,"buy:0.02"]
TradingView 설정:
신호가 나올 때까지 기다리는 중...
신호가 나올 때까지 기다리는 중..
신호가 나올 때까지 기다립니다.
...
로봇은 다음 신호를 받았습니다:
이런 방식으로 TradingView의 풍부한 차트 기능과 지표 알고리즘을 Inventor Quantitative Trading Platform의 전략 로봇과 함께 사용하여 원하는 자동화된 거래를 달성할 수 있습니다. TradingView의 전략을 JavaScript 및 Python 언어로 이식하는 것과 비교하면 난이도가 크게 낮아졌습니다.
"Monitoring Signal Order Robot"의 전략 코드는 학습 및 연구 전용입니다. 실제 사용을 위해서는 직접 최적화하고 조정해야 합니다. 선물 거래를 지원하며 시장 주문 모드로 설정하는 것이 좋습니다. 전략 코드를 참조하세요. 자세한 내용은 매개변수를 참조하세요.
이것은 단지 시작점일 뿐입니다. 질문이나 제안 사항이 있으면 메시지를 남겨주세요.
// 目前已经不支持:https://www.fmz.com/api/v1?access_key=xxx&secret_key=yyyy&method=CommandRobot&args=[186515,"ok12345"]这种方式,需要将参数编码,需要修改如下:
https://www.fmz.com/api/v1?access_key=xxx&secret_key=yyyy&method=CommandRobot&args=[186515%2C"ok12345"]
以前那个多简单明了啊。。。。[186515,"ok12345"]。。。。。为什么一定要修改成这么复杂的啊%5B186515%2C%22ok12345%22%5D
这个策略方案是一个简单的例子,只能做单个品种,多品种的可以参考另一个例子:
https://www.fmz.com/digest-topic/9794
"Flag":"{{strategy.order.id}}",
"Exchange":1,
"Currency":"1000SATS_USDT",
"ContractType":"swap",
"Price":"{{close}}",
"Action":"long",
"Amount":"33333"
}我的信号写成close了,为什么日志显示无法获取价格呢
这个代码就是策略交互这里,我测试1000sats这个交易对,我想的就是用收盘价开单,市价太贵了,但是会报错,我代码水平太差了,gpt用了找不出来具体的问题
这里测试信号指的是最终发到FMZ上的信息,你在trading view 上设置webhook 的时候写的是{{close}} 它实际发送的时候就是具体价格了。所以你在这里测试的时候只能填写具体价格,FMZ上没有、也不识别这个{{close}}占位符。
测试信号的时候填写具体价格,FMZ上不会识别你这个{{close}} ,这个是trading view上的占位符,文章看下,看明白就懂了。
这是您文章里关于这个的例子,因为这里-1都能识别是市价单,中间关于{close}也能识别,但是我查平台的api文档查不到什么对应市价单
我要怎么实现处理多个警报呢,比如同一时间,同一交易对,或者不同交易对,有多个警报传过来,但是我看我只能每秒处理一个,而且没有办法排序
有啊
我们可以自己用通用协议绑定吧?只是要求要填IP地址,这个IP地址要填哪个地址呢?
API 入口链接:https://coinw.pw/API
这个是coinw的现货API哇,coinw现货FMZ是已经支持的了,他们合约都没有接口的。您最好咨询下coinw。我问了他们客服,说是没有合约API。
你好大佬,我做的合约策略,开仓后有时中途会加仓,那么我最后要平仓的时候,用cover_long怎么平掉全部的仓位(因为不知道中间会加几次),"cover_long:1"里面的1改成什么,跪求代码
这个你可以具体设计的,比如你设计 请求里 cover_long:1, 改成 cover_long:all , 这样你在FMZ的这个 监听策略里把收到交互cover_long时修改一下, 判断如果是all,就全部平仓。要实现这个是要修改这个策略的。
// 全局变量
var BUY = "buy" // 注意:现货用的命令
var SELL = "sell" // 现货用的命令
var LONG = "long" // 期货用的命令
var SHORT = "short" // 期货用的命令
var COVER_LONG = "cover_long" // 期货用的命令
var COVER_SHORT = "cover_short" // 期货用的命令
......
....
..
.
} else if (eType == 1) {
var tradeInfo = null
var ticker = _C(exchange.GetTicker)
if (action == LONG) {
exchange.SetDirection("buy")
tradeInfo = IsMarketOrder ? exchange.Buy(-1, amount) : exchange.Buy(ticker.Sell, amount)
} else if (action == SHORT) {
exchange.SetDirection("sell")
tradeInfo = IsMarketOrder ? exchange.Sell(-1, amount) : exchange.Sell(ticker.Buy, amount)
} else if (action == COVER_LONG) { // COVER_LONG 就是 “cover_long” ,判断到是这个action ,进入这里的if
// 这里你再具体判断 all 之类的参数,去做全部平仓的操作设计,具体编写
exchange.SetDirection("closebuy")
tradeInfo = IsMarketOrder ? exchange.Sell(-1, amount) : exchange.Sell(ticker.Buy, amount)
} else if (action == COVER_SHORT) {
exchange.SetDirection("closesell")
tradeInfo = IsMarketOrder ? exchange.Buy(-1, amount) : exchange.Buy(ticker.Sell, amount)
} else {
Log("期货交易所不支持!", "#FF0000")
}
if (tradeInfo) {
Log("tradeInfo:", tradeInfo)
}
} else {
throw "eType error, eType:" + eType
}
acc = _C(exchange.GetAccount)
}
我的TV策略消息是这样的:订单{{strategy.order.action}}@{{strategy.order.contracts}}成交{{ticker}}。新策略仓位{{strategy.position_size}}
如果我想做合约的话,是不是要添加4个警报呢?做多、平多、做空、开空
webhook能不能引用策略里面的字段呢?还是要我写死才行?webhook里面的4种方式long、cover_long\short、cover_short怎么样才能和警报里面的消息对上吗?
使用FMZ的扩展API接收TV请求,可以获取Body内容,参看:https://www.fmz.com/api#直接验证
现在TV发出请求的url里,body里的数据都可以收到了。
老师您好,我按照您的步骤一步一步照搬下来,就是服务器选用的是发明者自带的服务器,但是TV那边已经发信号了但是发明者这边的机器人还是不执行信号命令,是不是因为服务器的原因?请您答疑!!
期货现货使用是一样的, 只是链接里面 参数替换一下而已。
var BUY = "buy"
var SELL = "sell"
var LONG = "long"
var SHORT = "short"
var COVER_LONG = "cover_long"
var COVER_SHORT = "cover_short"
long就是开多头仓位,short就是开空头仓位, cover_long 就是平多头,cover_short 平空头。
https://www.fmz.com/api/v1?access_key=e3809e173e23004821a9bfb6a468e308&secret_key=45a811e0009d91ad21154e79d4074bc6&method=CommandRobot&args=[191755,"buy:0.02"]
链接里面buy替换一下而已。
- 1
- 2























