지난 기사에서는 매우 간단한 파이썬 전략을 구현했습니다.
변환 후 전략 소스 코드:
'''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": ["Account information"],
"rows": []
}
tblTick = {
"type" : "table",
"title": "ticker",
"cols": ["Market information"],
"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)
이 코드 를 비교 해 보면, 이전 기사 의 코드 와 크게 다르다는 것 을 발견 해 보셨습니까?
사실, 거래 논리는 전혀 변경되지 않고 정확히 동일합니다. 우리는 단지 여러 종으로 전략을 수정합니다, 우리는 전략 매개 변수로서 이전 형태의
다음에는 함수로 거래 논리의 코드를 캡슐화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":[]
}
이 디자인은 각 거래 쌍이 자신의 매개 변수를 가질 수 있도록 허용합니다. 왜냐하면 각 거래 쌍은 큰 가격 차이를 가질 수 있기 때문에 매개 변수 또한 다를 수 있으며 때로는 차분 설정을 필요로 할 수 있습니다.
모든 함수를 취소 이 함수의 변화를 비교해 볼 수 있습니다. 이 함수는 단지 작은 코드를 수정하고, 그런 수정의 의도를 생각해보세요.
상태 표시줄 차트 데이터 상태 표시줄에 시장 데이터와 계정 자산 데이터를 표시하기 위해 차트를 추가하여 각 거래 대상의 대응 자산과 시장을 실시간으로 표시 할 수 있습니다. 위 디자인 아이디어를 익힌 후 파이썬 전략을 다종 전략으로 바꾸는 것이 쉽나요?
이 전략은 학습 및 백테스팅 목적으로만 사용되며, 관심있는 경우 최적화 및 업그레이드 할 수 있습니다.전략 주소