Утилиты для выполнения количественных торговых роботов с использованием Python

Автор:Маленькие мечты, Создано: 2020-02-14 21:56:58, Обновлено: 2023-10-10 21:13:38

img

Утилиты для выполнения количественных торговых роботов с использованием Python

Как мощная, гибкая и удобная для использования квантовая платформа, изобретательская квантовая платформа, несмотря на очень низкий порог использования и небольшое количество ресурсов, используемых роботами, но мы все равно хотим, чтобы роботы запускались, когда им нужно, а не останавливались, когда они должны. Например, при программировании товарных фьючерсов, количественной торговле, время открытия не занимает большую часть дня. Так мы очень надеемся, что робот будет работать только в открытие, и каждый день будет работать только в открытие. Изобретатели количественно расширяют интерфейс API для платформы торговли, контролируя запуск и остановку роботов в нужное время.

Если есть потребность, то делайте!

На самом деле весь код очень прост, и примеры с использованием интерфейсов API для расширения квантовых торговых платформ можно использовать напрямую.

Адрес:https://www.fmz.com/api#简单的例子

Функции, используемые непосредственно в примере:def api(method, *args)Интерфейс, который нам нужно вызвать, также прост, используя два следующих интерфейса (см. ФМЗ).

  • Рестартробот Перезагрузить интерфейс робота и передать параметры в идентификатор робота. Конкретное использованиеidНапример, вы можете позвонить:api('RestartRobot', id)

  • StopRobot Прекратите интерфейс робота, параметры тоже роботыID

    РоботыIDСмотреть, получить, скриншот:img

Призыв к Изобретателям КВТ-платформы расширения API требует использования Изобретателя КВТ-платформыAPI KEYЯ не знаю. Вы можете создавать свои собственные в управлении аккаунтамиAPI KEYЯ не знаю. Мы сделали этоAPI KEYВведение параметров в качестве стратегии. Доступ к учетной записи изобретателя на квантовой платформеAPI KEYСнимок:img

Все, что остается, это написать логику времени, которая очень проста, установить параметры времени:

["175708,14:55:33-15:10:33", ...]

Опустить число можно, чтобы установить больше подобных."175708,14:55:33-15:10:33"Настройки ⋅ Параметр времени - это JSON-строка, которая в программе кода анализируется в виде списка. Каждый элемент в списке представляет собой набор настроек для запуска/остановки робота. Это:

"175708,14:55:33-15:10:33"

Часть, предшествующая запятой, помещается с запятой.175708Для идентификатора робота, часть после запятой означает время запуска/остановки. В данном примере, бот с ID: 175708, начинается в 14:55:33 и останавливается в 15:10:33.

Затем в стратегии происходит непрерывный поиск, при котором на каждом поиске сначала получается текущее время, а затем, в зависимости от сравнения текущего времени с временем, решается, нужно ли запускать или останавливать робот. Если это вызвано, вы можете вызвать API (RestartRobot button, id) или API (StopRobot button, id) для запуска и остановки робота.

Полный код стратегии:

# -*- coding: utf-8 -*-
import time
import json

try:
    import md5
    import urllib2
    from urllib import urlencode
except:
    import hashlib as md5
    import urllib.request as urllib2
    from urllib.parse import urlencode

def api(method, *args):
    d = {
        'version': '1.0',
        'access_key': accessKey,
        'method': method,
        'args': json.dumps(list(args)),
        'nonce': int(time.time() * 1000),
        }

    d['sign'] = md5.md5(('%s|%s|%s|%d|%s' % (d['version'], d['method'], d['args'], d['nonce'], secretKey)).encode('utf-8')).hexdigest()
    return json.loads(urllib2.urlopen('https://www.fmz.com/api/v1', urlencode(d).encode('utf-8')).read().decode('utf-8'))

RobotParams = json.loads(strRobotParams)

def main():
    global RobotParams 
    arrParams = []
    nowDay = 0
    strPush = ""
    if isPushMsg:
        strPush = "@"

    for i in range(len(RobotParams)):
        param = {}
        arr = RobotParams[i].split(",")
        if len(arr) != 2:
            raise Exception("字符串配置错误:分隔符号,")
        param["id"] = arr[0]
        param["isProcessOpenThisDay"] = False
        param["isProcessCloseThisDay"] = False

        arr = arr[1].split("-")
        if len(arr) != 2:
            raise Exception("字符串配置错误:分隔符号-")

        begin = arr[0]
        arrBegin = begin.split(":")
        if len(arrBegin) != 3:
            raise Exception("字符串配置错误:起始时间分隔符号:")
        
        param["begin"] = {}
        param["begin"]["hour"] = float(arrBegin[0])
        param["begin"]["min"] = float(arrBegin[1])
        param["begin"]["sec"] = float(arrBegin[2])

        end = arr[1]
        arrEnd = end.split(":")
        if len(arrEnd) != 3:
            raise Exception("字符串配置错误:结束时间分隔符号:")            
        
        param["end"] = {}
        param["end"]["hour"] = float(arrEnd[0])
        param["end"]["min"] = float(arrEnd[1])
        param["end"]["sec"] = float(arrEnd[2])
        arrParams.append(param)

    # 测试
    Log("输出参数", arrParams, "#FF0000")  

    while True:
        nowTime = time.localtime(time.time())
        nowHour = nowTime.tm_hour 
        nowMin = nowTime.tm_min
        nowSec = nowTime.tm_sec
        
        tbl = {
            "type" : "table", 
            "title" : "msg", 
            "cols" : ["id", "begin", "end", "今天是否执行过启动", "今天是否执行过停止"],
            "rows" : []
        }

        for i in range(len(arrParams)):
            tbl["rows"].append([arrParams[i]["id"], json.dumps(arrParams[i]["begin"]), json.dumps(arrParams[i]["end"]), arrParams[i]["isProcessOpenThisDay"], arrParams[i]["isProcessCloseThisDay"]])
            if nowDay != nowTime.tm_mday:
                arrParams[i]["isProcessOpenThisDay"] = False
                arrParams[i]["isProcessCloseThisDay"] = False

            if arrParams[i]["isProcessOpenThisDay"] == False:
                if nowTime.tm_hour == arrParams[i]["begin"]["hour"] and nowTime.tm_min >= arrParams[i]["begin"]["min"] and nowTime.tm_sec >= arrParams[i]["begin"]["sec"]:
                    ret = api('RestartRobot', int(arrParams[i]["id"]))                    
                    arrParams[i]["isProcessOpenThisDay"] = True
                    Log("机器人ID:", arrParams[i]["id"], "执行启动,请登录平台检查是否启动成功", "扩展API返回值:", ret, strPush)

            if arrParams[i]["isProcessCloseThisDay"] == False:
                if nowTime.tm_hour == arrParams[i]["end"]["hour"] and nowTime.tm_min >= arrParams[i]["end"]["min"] and nowTime.tm_sec >= arrParams[i]["end"]["sec"]:
                    ret = api('StopRobot', int(arrParams[i]["id"]))
                    arrParams[i]["isProcessCloseThisDay"] = True
                    Log("机器人ID:", arrParams[i]["id"], "执行停止,请登录平台检查是否停止成功", "扩展API返回值:", ret, strPush)
        
        if nowDay != nowTime.tm_mday:
            nowDay = nowTime.tm_mday

        LogStatus(_D(), nowTime, "\n`" + json.dumps(tbl) + "`")
        Sleep(500)

Параметры робота:

img

Стремиться к тому, чтобы все было хорошо.

Снимокimg

Боты, подвергающиеся этой стратегии:img

Политический адрес:https://www.fmz.com/strategy/184600

Конец

В качестве примера можно привести расширенные API для квантовой торговой платформы, с помощью которых можно создать собственную квантовую торговую платформу на основе FMZ. Этот робот-тимер имеет сравнительно простую конструкцию, просто не имеет мозга до времени запуска, до времени остановки, и не включает в себя механизмы успешного запуска, проверки, аномальных повторных попыток и т. Д., Интересно, что можно добавить функции, расширить. Стратегия для учебы


Связанные

Больше