이 신호를 수신하는 절차를 어떻게 변경해야 하는지 알려주세요.

저자:제터, 창작: 2023-01-26 20:31:05, 업데이트:

/* 백테스트 시작: 2022-01-15 00:00:00 끝: 2023-01-21 00:00:00 기간: 1시간 기본 기간: 15m 거래소: {eid:Futures_Binance,currency:ETH_USDT} */

// 신호 구조 var 템플릿 = { 플래그: 45M103Buy, // 로그, 임의로 지정할 수 있습니다 교환: 1, // 교환을 지정하는 거래 쌍 화폐: ETH_USDT , // 거래 쌍 ContractType: swap, // 계약 유형,swap,quarter,next_quarter, 현금 채용점 Price: -1, // 오픈 또는 평상시 가격, -1는 시장 가격 액션: long, // 거래 유형[buy: 현장 구매, sell: 현장 판매, long: 선물 더 많이, short: 선물 공백, closesell: 선물 구매 공백, closebuy: 선물 판매 비쌉니다] 양: 0, // 거래량 ♪ ♪

var BaseUrl = https://www.fmz.com/api/v1 // FMZ 확장 API 인터페이스 주소 var RobotId = _G() // 현재 디스크 ID var Success = #5cb85c // 성공 색상 var Danger = #ff0000 // 위험한 색상 var Warning = #f0ad4e // 경고 색상 var buffSignal = []

// 확인 신호 메시지 형식 function DiffObject ((object1, object2) { const keys1 = Object.keys ((object1)) const keys2 = Object.keys ((object2)) if (keys1.length!== keys2.length) { false를 반환합니다 ♪ ♪ for (let i = 0; i < keys1.length; i++) { if (keys1[i]!== keys2[i]) { false를 반환합니다 ♪ ♪ ♪ ♪ true 를 반환합니다 ♪ ♪

체크 신호 (Signal) { 시그널.프라이스 = 파스 플로트 (Signal.Price) 신호.자금 = 파스 플로트 (Signal.Amount) 만약 (Signal.Exchange숫자는 정수입니다.Signal.Exchange) 로그 ( 거래소의 최소 번호는 1이며 정수, 위험) 복귀 ♪ ♪ if (Signal.Amount <= 0 の の typeof ((Signal.Amount)!= number ) { Log (신호.Amount, Danger) 는 0보다 작지 않아야 하며, 숫자 타입의 log, typeof (신호.Amount, Danger) 이다. 복귀 ♪ ♪ if (typeof ((Signal.Price)!= number) { 로그 (의 가격은 수적, 위험) 복귀 ♪ ♪ if (Signal.ContractType == spot && Signal.Action!= buy && Signal.Action!= sell) { 로그 ( 명령어는 현상, Actions Error, Actions:??, Signal.Actions, Danger) 복귀 ♪ ♪ if (Signal.ContractType!= spot && Signal.Action!= long && Signal.Action!= short && Signal.Action!= closesell && Signal.Action!= closebuy) { Log ( 명령어는 동작 선물,Action 오류,Action:, Signal.Action, Danger) 복귀 ♪ ♪ true 를 반환합니다 ♪ ♪

함수 명령Robot ((url, accessKey, secretKey, robotId, cmd) { /https://www.fmz.com/api/v1?access_key=xxx&secret_key=xxx&method=CommandRobot&args=[xxx+""] url = url + ?access_key= + accessKey + &secret_key= + secretKey + &method=CommandRobot&args=[ + robotId + ,+""] var postData = { 메소드: POST data:cmd ♪ ♪ var headers = User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_9_3) AppleWebKit/537.36 (KHTML, like Gecko) 크롬/35.0.1916.153 사파리/537.36 \nContent-Type: application/json var ret = HttpQuery ((url, postData, , 헤더) Log (( 모의 트레이딩뷰의 웹후크 요청, 테스트를 위한 POST 요청을 전송:??, url, body:??, cmd, 응답:??, ret) ♪ ♪

함수 createManager() { var self = {} self.tasks = []

self.process = function() {
    var processed = 0
    if (self.tasks.length > 0) {
        _.each(self.tasks, function(task) {
            if (!task.finished) {
                processed++
                self.pollTask(task)
            }
        })
        if (processed == 0) {
            self.tasks = []
        }
    }
}

self.newTask = function(signal) {
    // {"Flag":"45M103Buy","Exchange":1,"Currency":"BTC_USDT","ContractType":"swap","Price":"10000","Action":"buy","Amount":"0"}
    var task = {}
    task.Flag = signal["Flag"]
    task.Exchange = signal["Exchange"]
    task.Currency = signal["Currency"]
    task.ContractType = signal["ContractType"]
    task.Price = signal["Price"]
    task.Action = signal["Action"]
    task.Amount = signal["Amount"]
    task.exchangeIdx = signal["Exchange"] - 1
    task.pricePrecision = null
    task.amountPrecision = null 
    task.error = null 
    task.exchangeLabel = exchanges[task.exchangeIdx].GetLabel()
    task.finished = false 
    
    Log("创建任务:", task)
    self.tasks.push(task)
}

self.getPrecision = function(n) {
    var precision = null 
    var arr = n.toString().split(".")
    if (arr.length == 1) {
        precision = 0
    } else if (arr.length == 2) {
        precision = arr[1].length
    } 
    return precision
}

self.pollTask = function(task) {
    var e = exchanges[task.exchangeIdx]
    var name = e.GetName()
    var isFutures = true
    e.SetCurrency(task.Currency)
    if (task.ContractType != "spot" && name.indexOf("Futures_") != -1) {
        // 非现货,则设置合约
        e.SetContractType(task.ContractType)
    } else if (task.ContractType == "spot" && name.indexOf("Futures_") == -1) {
        isFutures = false 
    } else {
        task.error = "指令中的ContractType与配置的交易所对象类型不匹配"
        return 
    }
    
    var depth = e.GetDepth()
    if (!depth || !depth.Bids || !depth.Asks) {
        task.error = "订单薄数据异常"
        return 
    }
    
    if (depth.Bids.length == 0 && depth.Asks.length == 0) {
        task.error = "盘口无订单"
        return 
    }
    
    _.each([depth.Bids, depth.Asks], function(arr) {
        _.each(arr, function(order) {
            var pricePrecision = self.getPrecision(order.Price)
            var amountPrecision = self.getPrecision(order.Amount)
            if (Number.isInteger(pricePrecision) && !Number.isInteger(self.pricePrecision)) {
                self.pricePrecision = pricePrecision
            } else if (Number.isInteger(self.pricePrecision) && Number.isInteger(pricePrecision) && pricePrecision > self.pricePrecision) {
                self.pricePrecision = pricePrecision
            }
            if (Number.isInteger(amountPrecision) && !Number.isInteger(self.amountPrecision)) {
                self.amountPrecision = amountPrecision
            } else if (Number.isInteger(self.amountPrecision) && Number.isInteger(amountPrecision) && amountPrecision > self.amountPrecision) {
                self.amountPrecision = amountPrecision
            }
        })
    })

    if (!Number.isInteger(self.pricePrecision) || !Number.isInteger(self.amountPrecision)) {
        task.err = "获取精度失败"
        return 
    }
    
    e.SetPrecision(self.pricePrecision, self.amountPrecision)
    
    // buy:现货买入 , sell:现货卖出 , long:期货做多 , short:期货做空 , closesell:期货买入平空 , closebuy:期货卖出平多
    var direction = null 
    var tradeFunc = null 
    if (isFutures) {
        switch (task.Action) {
            case "long": 
                direction = "buy"
                tradeFunc = e.Buy 
                break
            case "short": 
                direction = "sell"
                tradeFunc = e.Sell
                break
            case "closesell": 
                direction = "closesell"
                tradeFunc = e.Buy 
                break
            case "closebuy": 
                direction = "closebuy"
                tradeFunc = e.Sell
                break
        }
        if (!direction || !tradeFunc) {
            task.error = "交易方向错误:" + task.Action
            return 
        }
        e.SetDirection(direction)
    } else {
        if (task.Action == "buy") {
            tradeFunc = e.Buy 
        } else if (task.Action == "sell") {
            tradeFunc = e.Sell 
        } else {
            task.error = "交易方向错误:" + task.Action
            return 
        }
    }
    var id = tradeFunc(task.Price, task.Amount)
    if (!id) {
        task.error = "下单失败"
    }
    
    task.finished = true
}

return self

}

var 관리자 = createManager function HandleCommand ((signal) { 함수와 명령어 // 인터랙션 명령어 수신 여부를 검사합니다 if (signal) { Log (( 상호작용 명령어 수신:??, signal) // 상호작용 명령어를 수신, 상호작용 명령어를 인쇄 } else { return // 수신하지 않은 경우 직접 반환, 처리하지 않습니다 ♪ ♪

// 检测交互指令是否是测试指令,测试指令可以由当前策略交互控件发出来进行测试
if (signal.indexOf("TestSignal") != -1) {
    signal = signal.replace("TestSignal:", "")
    // 调用FMZ扩展API接口,模拟Trading View的webhook,交互按钮TestSignal发送的消息:{"Flag":"45M103Buy","Exchange":1,"Currency":"BTC_USDT","ContractType":"swap","Price":"10000","Action":"buy","Amount":"0"}
    commandRobot(BaseUrl, FMZ_AccessKey, FMZ_SecretKey, RobotId, signal)
} else if (signal.indexOf("evalCode") != -1) {
    var js = signal.split(':', 2)[1]
    Log("执行调试代码:", js)
    eval(js)
} else {
    // 处理信号指令
    objSignal = JSON.parse(signal)
    if (DiffObject(Template, objSignal)) {
        Log("接收到交易信号指令:", objSignal)
        buffSignal.push(objSignal)
        
        // 检查交易量、交易所编号
        if (!CheckSignal(objSignal)) {
            return
        }
        
        // 创建任务
        manager.newTask(objSignal)
    } else {
        Log("指令无法识别", signal)
    }
}

}

function main (() { 로그 (WebHook) 주소: 오, 오https://www.fmz.com/api/v1?access_key= + FMZ_AccessKey + &secret_key= + FMZ_SecretKey + &method=CommandRobot&args=[ + RobotId + ,+""], Danger) Log (( 거래 유형[buy: 현상 구매, sell: 현상 판매, long: 선물 더 많이, short: 선물 공백, closesell: 선물 구매 공백, closebuy: 선물 판매 평평하다]??, Danger) 로그 ( 명령어 템플릿:??, JSON.stringify (), Danger)

while (true) {
    try {
        // 处理交互
        HandleCommand(GetCommand())
        
        // 处理任务
        manager.process()
        
        if (buffSignal.length > maxBuffSignalRowDisplay) {
            buffSignal.shift()
        }
        var buffSignalTbl = {
            "type" : "table",
            "title" : "信号记录",
            "cols" : ["Flag", "Exchange", "Currency", "ContractType", "Price", "Action", "Amount"],
            "rows" : []
        }
        for (var i = buffSignal.length - 1 ; i >= 0 ; i--) {
            buffSignalTbl.rows.push([buffSignal[i].Flag, buffSignal[i].Exchange, buffSignal[i].Currency, buffSignal[i].ContractType, buffSignal[i].Price, buffSignal[i].Action, buffSignal[i].Amount])
        }
        LogStatus(_D(), "\n", "`" + JSON.stringify(buffSignalTbl) + "`")
        Sleep(1000 *SleePinterval )
    } catch (error) {
        Log("e.name:", error.name, "e.stack:", error.stack, "e.message:", error.message)
        Sleep(1000 * 5)
    }
}

}


더 많은

이 글의 내용은 이쪽에서 참조하십시오.exchange.GetPosition ((), 현재 보유 정보를 얻는다. 0보다 더 많은 보유가 있으면 주문을 하지 않는다.

작은 꿈전략 디자인은 자신의 필요에 따라 작성할 수 있습니다.

제터좋아요. 감사합니다. 이 문자는 어떻게 되어있나요? var nowRefPosAmount = getPosAmount ((_C ((exchange.GetPosition), ct) var x = owRefPosAmount.long var y = owRefPosAmount.short CT가 필요해요?

제터좋아요. 감사합니다.