Gunakan API Ekstensi Platform Perdagangan Kuantitatif Inventor untuk mengimplementasikan perdagangan sinyal peringatan TradingView
API ekstensi Inventor Quantitative Trading Platform baru-baru ini ditingkatkan untuk mendukung mode akses langsung, yang memudahkan pengiriman sinyal alarm TradingView ke robot Inventor Quantitative Trading Platform untuk mewujudkan perdagangan otomatis. Jika Anda masih belum tahu apa itu API ekstensi, izinkan saya menjelaskannya secara rinci.
Ekstensi API platform perdagangan kuantitatif Inventor
Tautan ke bagian relevan dari dokumentasi API Inventor
Fungsi utama API yang diperluas adalah untuk menyediakan antarmuka bagi berbagai fungsi pada platform perdagangan kuantitatif penemu operasi terprogram, seperti memulai robot secara berkelompok di waktu yang sama, memulai dan menghentikan robot pada waktu yang dijadwalkan, membaca detail informasi robot, dan lain-lain. Kami menggunakan Inventor Quantitative Trading Platform Extension API untuk mengimplementasikan perdagangan sinyal peringatan TradingView. Persyaratan ini hanya memerlukan ekstensi API.CommandRobot(RobotId, Cmd)Antarmuka dapat mengirimkan instruksi interaktif ke robot dengan ID yang ditentukan. Robot dapat melakukan operasi yang sesuai (seperti menempatkan pesanan untuk membeli atau menjual) setelah menerima instruksi.
Untuk menggunakan API ekstensi, pertama-tama Anda perlu membuat akun penemu Anda sendiriAPI KEY:

API KEYKuncinya adalahaccess keyDansecret keykomposisi,API KEYIni adalah kunci platform perdagangan kuantitatif yang ditemukan oleh operasi terprogram, jadi ini harus disimpan dengan benar dan tidak pernah diungkapkan. Membuat ekstensi FMZAPI KEYAnda dapat menentukan izin saat Anda menggunakanAPI KEYBerikan AksesCommandRobot(RobotId, Cmd)Untuk contoh ini, demi alasan keamanan, berikan izin hanya kepada ekstensi FMZ.API KEYMemberkatiCommandRobot(RobotId, Cmd)Izin akses untuk antarmuka.
Mode akses langsung untuk API ekstensi
Mode akses langsung berartiAPI KEYTulis langsung di kueri URL. Misalnya, URL untuk mengakses API ekstensi Inventor Quantitative Trading Platform dapat ditulis sebagai:
https://www.fmz.com/api/v1?access_key=xxx&secret_key=yyyy&method=CommandRobot&args=[186515,"ok12345"]
di dalam,https://www.fmz.com/api/v1adalah alamat antarmuka,?Setelah ituQuery,parameteraccess_keyContoh kunci diwakili oleh xxx (isi akses kunci akun FMZ Anda sendiri saat menggunakan), parametersecret_keyKunci rahasia diwakili oleh yyyy (isi sendiri kunci rahasia akun Anda saat menggunakannya), parametermethodAdalah nama spesifik dari antarmuka API yang diperluas yang akan diakses.argsUntuk dipanggilmethodParameter antarmuka.
Kami menggunakan TradingView sebagai sumber sinyal untuk mengirim perintah perdagangan ke robot platform perdagangan kuantitatif milik penemu.CommandRobotAntarmuka ini.
TradingView
Pertama-tama, Anda perlu memiliki akun TradingView Pro. Fitur WebHood dalam alarm tidak tersedia di level Basic. Kita pergi ke grafik di TradingView.
Menambahkan indikator ke grafik, tetapi juga algoritma skrip lainnya. Di sini kami menggunakan yang paling umum digunakanMACDIndikator, lalu atur periode K-line menjadi 1 menit (untuk memicu sinyal lebih cepat dan memudahkan demonstrasi).
Klik kanan pada grafik dan pilih Tambahkan Peringatan dari menu pop-up.
Diatur di jendela pop-up "Peringatan"WebHookPada langkah ini, Anda tidak perlu terburu-buru untuk mengaturnya. Pertama-tama mari kita jalankan robot yang memantau sinyal pada Platform Perdagangan Kuantitatif Inventor.
Robot pemesan sinyal pemantauan
Kode sumber strategi:
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)
}
}
Kode strategi sangat sederhana, deteksiGetCommandNilai pengembalian fungsi, ketika pesan interaktif dikirim ke program kebijakan,GetCommandFungsi ini akan mengembalikan pesan ini, dan kemudian program strategi akan melakukan operasi perdagangan yang sesuai berdasarkan konten pesan. Tombol interaktif telah disiapkan pada strategi ini, yang dapat menguji fungsi interaktif. Misalnya, jalankan strategi ini dan konfigurasikan robot dengan simulasi pertukaran Inventor Quantitative Trading Platform.WexApp。
Klik tombol interaksi untuk menguji kemampuan robot dalam menerima perintah beli.
Anda dapat melihat bahwa string perintah yang diterima oleh robot adalah:buy:0.01。
Kita hanya perlu membuat URL permintaan WebHook mengakses Inventor Quantitative Trading Platform Extension API saat peringatan TradingView dipicu.CommandRobotSaat menggunakan antarmuka, parameter yang dibawa adalahbuy:0.01Itu saja.
Menyiapkan WebHook TradingView
Kembali ke TradingView, kami mengisi URL WebHook. Memberiaccess_key、secret_keyIsi parameter Anda sendiriAPI KEY。methodSudah diperbaiki, kita hanya perlu mengaksesCommandRobotAntarmuka API yang diperluas ini,argsParameternya adalah[机器人ID,命令字符串]Dalam bentuk, kita bisa langsung mendapatkan ID robot melalui halaman robot, seperti yang ditunjukkan pada gambar:

Kali ini kita biarkan sinyal terpicu dan membeli 0,02 koin. Rangkaian perintahnya adalah:"buy:0.02". Ini melengkapi URL WebHook. Metode ini hanya mendukung penulisan sinyal di URL. Jika Anda ingin mendapatkan konten pesan peringatan yang dapat dikeluarkan oleh strategi TV itu sendiri, lihat 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"]
Pengaturan di TradingView:
Menunggu sinyal untuk dipicu...
Menunggu sinyal untuk dipicu..
Menunggu sinyal untuk dipicu.
...
Robot menerima sinyal:
Dengan cara ini, Anda dapat menggunakan fungsi grafik yang kaya dan algoritma indikator pada TradingView bersama dengan robot strategi dari Inventor Quantitative Trading Platform untuk mencapai perdagangan otomatis yang Anda inginkan. Dibandingkan dengan memindahkan strategi pada TradingView ke dalam bahasa JavaScript dan Python, kesulitannya sangat berkurang.
Kode strategi "Monitoring Signal Order Placing Robot" hanya untuk pembelajaran dan penelitian. Anda perlu mengoptimalkan dan menyesuaikannya sendiri untuk penggunaan yang sebenarnya. Robot ini mendukung futures dan disarankan untuk mengaturnya ke mode market order. Lihat strateginya parameter kode untuk rincian.
Ini hanyalah titik awal. Jika Anda memiliki pertanyaan atau saran, silakan tinggalkan pesan.
// 目前已经不支持: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























