Руководство поможет вам перевести одноразовые стратегии Python на многоразовые.

Автор:Маленькие мечты, Создано: 2020-01-20 17:33:36, Обновлено: 2023-10-17 21:18:46

img

Первое - руководство, которое научит вас переводить одноразовые стратегии Python в многоразовые.

Например, в прошлом выпуске мы использовали очень простую стратегию Python:"Стратегия преследования и гибели Python"Эта стратегия позволяет управлять одним аккаунтом, чтобы проводить программированные сделки на одной паре сделок. Принцип очень прост, иногда мы хотим использовать одну и ту же логику, чтобы управлять различными парами сделок. Можно создать несколько роботов, настроить различные пары сделок, чтобы торговать различными валютами.

Измененный источник стратегии:

'''backtest
start: 2019-02-20 00:00:00
end: 2020-01-10 00:00:00
period: 1m
exchanges: [{"eid":"OKEX","currency":"BTC_USDT"},{"eid":"OKEX","currency":"ETH_USDT","stocks":30},{"eid":"OKEX","currency":"LTC_USDT","stocks":100}]
'''

import time
import json

params = {
    "arrBasePrice": [-1, -1, -1],     # -1
    "arrRatio": [0.05, 0.05, 0.05],         # 0.05
    "arrAcc": [],           # _C(exchange.GetAccount)
    "arrLastCancelAll": [0, 0, 0], # 0
    "arrMinStocks": [0.01, 0.01, 0.01],     # 0.01
    "arrPricePrecision": [2, 2, 2], # 2
    "arrAmountPrecision": [3, 2, 2], # 2
    "arrTick":[]
}

def CancelAll(e):
    while True : 
        orders = _C(e.GetOrders)
        for i in range(len(orders)) :
            e.CancelOrder(orders[i]["Id"], orders[i])
        if len(orders) == 0 :
            break
        Sleep(1000)

def process(e, index):
    global params
    ticker = _C(e.GetTicker)
    params["arrTick"][index] = ticker
    if params["arrBasePrice"][index] == -1 :
        params["arrBasePrice"][index] = ticker.Last
    if ticker.Last - params["arrBasePrice"][index] > 0 and (ticker.Last - params["arrBasePrice"][index]) / params["arrBasePrice"][index] > params["arrRatio"][index]:
        params["arrAcc"][index] = _C(e.GetAccount)
        if params["arrAcc"][index].Balance * params["arrRatio"][index] / ticker.Last > params["arrMinStocks"][index]:
            e.Buy(ticker.Last, params["arrAcc"][index].Balance * params["arrRatio"][index] / ticker.Last)
            params["arrBasePrice"][index] = ticker.Last
    if ticker.Last - params["arrBasePrice"][index] < 0 and (params["arrBasePrice"][index] - ticker.Last) / params["arrBasePrice"][index] > params["arrRatio"][index]: 
        params["arrAcc"][index] = _C(e.GetAccount)
        if params["arrAcc"][index].Stocks * params["arrRatio"][index] > params["arrMinStocks"][index]:
            e.Sell(ticker.Last, params["arrAcc"][index].Stocks * params["arrRatio"][index])
            params["arrBasePrice"][index] = ticker.Last
    ts = time.time()
    if ts - params["arrLastCancelAll"][index] > 60 * 5 :
        CancelAll(e)
        params["arrLastCancelAll"][index] = ts 

def main():
    global params
    
    for i in range(len(exchanges)) :    
        params["arrAcc"].append(_C(exchanges[i].GetAccount))
        params["arrTick"].append(_C(exchanges[i].GetTicker))
        exchanges[i].SetPrecision(params["arrPricePrecision"][i], params["arrAmountPrecision"][i])

    for key in params :
        if len(params[key]) < len(exchanges):
            raise "params error!"

    while True:
        tblAcc = {
            "type" : "table",
            "title": "account",
            "cols": ["账户信息"], 
            "rows": []
        }        

        tblTick = {
            "type" : "table",
            "title": "ticker",
            "cols": ["行情信息"], 
            "rows": []
        }
        for i in range(len(exchanges)): 
            process(exchanges[i], i)

        for i in range(len(exchanges)):
            tblAcc["rows"].append([json.dumps(params["arrAcc"][i])])
            tblTick["rows"].append([json.dumps(params["arrTick"][i])])

        LogStatus(_D(), "\n`" + json.dumps([tblAcc, tblTick]) + "`")
        Sleep(500)

Второе - найти разницу.

Посмотрите на код, и вы увидите, что он сильно отличается от того, что было описано в предыдущей статье. Фактически логика транзакции абсолютно та же, без каких-либо изменений, только мы изменили стратегию на многообразие, так что нельзя использовать предыдущие параметры в качестве параметров стратегии.

img

Затем мы записываем эту часть кода в логику транзакций в функцию.processВ принципе, в стратегическом мастер-лопе, в зависимости от добавленной транзакции, двойная итерация вызывает эту функцию, позволяя каждой транзакционной паре выполнять один логический код.

  • В связи с этим, он призвал к тому, чтобы все эти люди были освобождены.

    for i in range(len(exchanges)): 
        process(exchanges[i], i)
    
  • Параметры стратегии:

    params = {
        "arrBasePrice": [-1, -1, -1],           # -1
        "arrRatio": [0.05, 0.05, 0.05],         # 0.05
        "arrAcc": [],                           # _C(exchange.GetAccount)
        "arrLastCancelAll": [0, 0, 0],          # 0
        "arrMinStocks": [0.01, 0.01, 0.01],     # 0.01
        "arrPricePrecision": [2, 2, 2],         # 2
        "arrAmountPrecision": [3, 2, 2],        # 2
        "arrTick":[]
    }
    

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

  • Функция CancelAll

    Сравните это с изменением функции. Функция просто изменяет код немного, а затем думает о намерении изменить его.

  • Данные диаграммы с панелью состояния

    Добавлен график, показывающий данные рынка и данные активов счета в строке состояния, чтобы показать соответствующие активы и рынки в режиме реального времени для каждого объекта биржи.

С учетом этих дизайнерских идей, не так ли просто изменить одну стратегию Python в несколько разновидностей?

Третье, повторное тестирование.

img

img

img

Стратегия предназначена только для учебы ссылки, повторного тестирования, заинтересованных в оптимизации обновления.Стратегический адрес


Связанные

Больше

БбббвввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввввМэн, пожалуйста, почему вы не настроили настройку exchange.SetDirection (("покупать") и есть e. Не exchange.

Большой черный коньКаков минимальный капитал этой стратегии?

Большой черный коньКак не торговаться, пол дня без ответа.

Большой черный коньХорошо, хорошо, хорошо, я сделал это, я сделал это в монете, не удивительно.

Большой черный конь/upload/asset/164f3fe6e84331d800583.png Сейчас все в порядке, но у меня есть деньги в счете, сколько минимального капитала вам нужно вложить в эту стратегию?

Большой черный конь/upload/asset/16495fcb1185338f8af27.png Добавлен IP-адрес администратора.

Большой черный коньGetAccount: 400: {"error_message":"Invalid IP","code":30011,"error_code":"30011","message":"Invalid IP"} IP Я добавил его в API, но почему-то ошибся.

Большой черный конь/upload/asset/164330beccf32fc55e7b6.png Как это сделать?

Большой черный коньСколько настроить циклы роботов K-линии

Маленькие мечтыНе используя реальные диски, эта стратегия предназначена для обучения, обучения и может быть изменена, расширена и оптимизирована самостоятельно.

Маленькие мечтыВ частности, можно посмотреть на этот стратегический исходный код. Стратегия открыта, стратегическая логика очень проста - это охота на крах и падение.

Маленькие мечтыПри запросе API KEY IP-адрес, установленный для предоставления доступа, является адресом WHITELIST. После этого только этот IP-адрес может использоваться для доступа к API-интерфейсу с помощью вашего API KEY.

Маленькие мечтыНа сервере, на котором находится администратор, устанавливается Python.

Маленькие мечтыЭта политика не касается K-линий, в любом случае настройка действует, повторное слово, поскольку влияет на гранулированность тика, установлено на 1 минуту.