tradingview Сигнальный торговый робот ошибка и как ее решить

Автор:Нихао153159, Создано: 2021-01-02 07:06:59, Обновлено:

Новички хотят автоматически торговать валютой с помощью сигнала trading view. После развертывания робота возникает ошибка. Код является копией стратегии выполнения сигналов TradingViewWebHook. /* - Формат интерактивной командной строки action:amount action: buy, sell, long, short, cover_long, cover_short, spk, bpk - Тип биржи Валюта eType: 0 spot, 1 futures

// параметры // var IsMarketOrder = ложный // var QuotePrecision = 2 // var BasePrecision = 2

// Фьючерсные параметры // var Ct =

// Глобальные переменные var BUY = купить var SELL = ссылка на ссылку var LONG = длинный цыпленок var SHORT = шорт шорт var COVER_LONG = длинная крышка var COVER_SHORT = ковер_короткий ковер var SPK = spk var BPK = bpk

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 if (action == SPK) {   // 卖出平多仓,卖出开空仓
                exchange.SetDirection("closebuy")
                var tradeInfo1 = IsMarketOrder ? exchange.Sell(-1, amount) : exchange.Sell(ticker.Buy, amount)
                exchange.SetDirection("sell")
                var tradeInfo2 = IsMarketOrder ? exchange.Sell(-1, amount) : exchange.Sell(ticker.Buy, amount)
                tradeInfo = [tradeInfo1, tradeInfo2]
            } else if (action == BPK) {   // 买入平空仓,买入开多仓
                exchange.SetDirection("closesell")
                var tradeInfo1 = IsMarketOrder ? exchange.Buy(-1, amount) : exchange.Buy(ticker.Sell, amount)
                exchange.SetDirection("buy")
                var tradeInfo2 = IsMarketOrder ? exchange.Buy(-1, amount) : exchange.Buy(ticker.Sell, amount)
                tradeInfo = [tradeInfo1, tradeInfo2]
            } 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)
}

}


Больше информации

Король хип-хапаНикаких ошибок, как посмотреть.

Нихао153159Новички Учитель, как настроить бессрочный контракт btcusdt, конкретно, какую строку кода изменить

Нихао153159Буйнулл возвращает sellnull после получения инструкции о сделке.

ТраваНедостаточно средств на счету

Нихао153159Фьючерсные роботы ошибаются. 2021-01-02 23:40:08 Информация Фьючерсные биржи не поддерживаются! 2021-01-02 23:40:05 Информация Фьючерсные биржи не поддерживаются! 2021-01-02 23:38:23 Информация {"InstrumentID:"BTCUSDT","instrument:"BTCUSDT"} Контракт настройки: swap 2021-01-02 23:38:23 Информация Добавлена биржа для фьючерсной биржи: Futures_Binance Спасибо.

Нихао153159Дата Платформа Тип Цена Количество Информация 2021-01-02 23:39:01 Информация sellInfo: null 2021-01-02 23:39:01 Binance Ошибка Sell ((-1, 0.01): 400: {"code":-2010, "msg:"Account has insufficient balance for requested action"} 2021-01-02 23:38:53 Информация buyInfo: null 2021-01-02 23:38:53 Binance Ошибка Buy ((-1, 0.01): 400: {"code":-2010, "msg:"Account has insufficient balance for requested action"}