संसाधन लोड हो रहा है... लोड करना...

कृपया मुझे बताएं कि अगर एक ही दिशा में स्टॉक है और नए ऑर्डर नहीं दिए जाते हैं, तो सिग्नल प्राप्त करने की प्रक्रिया को कैसे संशोधित किया जाए?

लेखक:जेटर, बनाया गयाः 2023-01-26 20:31:05, अद्यतन किया गयाः

/*बैकटेस्ट प्रारंभः 2022-01-15 00:00:00 अंतः 2023-01-21 00:00:00 अवधिः 1 घंटा आधार अवधिः 15 मीटर एक्सचेंजोंः [{eid:Futures_Binance,currency:ETH_USDT}] */

// सिग्नल संरचना var टेम्पलेट = { Flag: 45M103Buy, // चिह्न, आप चाहें तो निर्दिष्ट कर सकते हैं एक्सचेंजः 1, // एक्सचेंज के लिए निर्दिष्ट लेनदेन जोड़ी मुद्राः ETH_USDT, // लेनदेन जोड़ी ContractType: swap टैंक, // अनुबंध प्रकार, swap, quarter, next_quarter, नकदी भरने का स्थान Price: -1, // शुरुआती या समापन मूल्य, -1 बाजार मूल्य Action: long, // लेनदेन प्रकार [ buy: तत्काल खरीदें, sell: तत्काल बेचें, long: वायदा अधिक करें, short: वायदा खाली करें, closesell: वायदा खरीदें खाली करें, closebuy: वायदा सस्ता करें] Amount: 0, // लेनदेन की मात्रा }

var BaseUrl = https://www.fmz.com/api/v1 // FMZ एक्सटेंशन एपीआई इंटरफ़ेस पता var RobotId = _G() // वर्तमान डिस्क आईडी var Success = #5cb85c // सफल रंग var Danger = #ff0000 // खतरनाक रंग var Warning = #f0ad4e // चेतावनी रंग var buffSignal = []

// सत्यापन संकेत संदेश प्रारूप functionObject ((object1, object2) { const keys1 = Object.keys ((object1) const keys2 = Object.keys ((object2)) if (keys1.length!== keys2.length) { return false गलत लौटाता है } for (let i = 0; i < keys1.length; i++) { if (keys1[i]!== keys2[i]) { return false गलत लौटाता है } } return true (वास्तविक लौटाएँ) }

कार्य चेकसिग्नल ((सिग्नल) { Signal.Price = parseFloat ((सिग्नल.प्राइस) Signal.Amount = parseFloat(Signal.Amount) यदि (Signal.Exchangeसंख्या पूर्णांक है।Signal.Exchange) { लॉग (जोड़े के लिए न्यूनतम संख्या 1 है, और जोड़े के लिए एक पूर्णांक है, खतरे) return } if (Signal.Amount <= 0 の の typeof ((Signal.Amount)!= number ) { लॉग (~) लेनदेन की मात्रा 0 से कम नहीं हो सकती है, और संख्यात्मक प्रकार के लिए लॉग, typeof (~) Signal.Amount, Danger return } if (typeof ((Signal.Price)!= number ) { लॉग (प्लान की कीमत एक संख्यात्मक प्लान होनी चाहिए, खतरे) return } if (Signal.ContractType == spot टैब && Signal.Action!= buy टैब && Signal.Action!= sell टैब) { लॉग (अभिनय आदेश के लिए ऑपरेशन स्टॉक, कार्रवाई त्रुटि, कार्रवाईः लॉग, संकेत.कार्य, खतरा) return } if (Signal.ContractType!= spot टैब && Signal.Action!= long टैब && Signal.Action!= short टैब && Signal.Action!= closesell टैब && Signal.Action!= closebuy टैब) { लॉग (अभियान के लिए लॉग निर्देश, एक्शन त्रुटि, एक्शनः लॉग, Signal.Action, Danger) return } return 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 = { method: पोस्ट टाइप करें, data:cmd } var headers = User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_9_3) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/35.0.1916.153 Safari/537.36\nContent-Type: application/json टैब var ret = HttpQuery ((url, postData, ऐरे, हेडर) लॉग (<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<< }

फ़ंक्शन createManager ((() { var स्वयं = {} 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 ((सिग्नल) { // जांचें कि क्या इंटरैक्टिव निर्देश प्राप्त हुआ है if (सिग्नल) { लॉग (( इंटरैक्टिव कमांड प्राप्त करेंः, 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) लॉग ((बंद व्यापार प्रकार[ buy: नकदी खरीद, sell: नकदी बिक्री, long: वायदा अधिक करना, short: वायदा खाली करना, closesell: वायदा खाली में खरीदना, closebuy: वायदा सस्ते में बेचना] लॉग () निर्देश टेम्पलेटः लॉग, JSON.stringify ((टेम्पलेट), खतरे

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 क्या आप उस सीटी को चाहते हैं?

जेटरबहुत अच्छा. धन्यवाद!