Использование стратегии котельной пластины, предполагающей покупку и продажу одной акции (только длинная / каждый ордер на покупку связан с ордером на продажу).
По какой-то причине, когда я продаю акцию, она регистрирует стоимость сделка (цена акций *) на ту же сумму, которая была установлена при открытии позиции, несмотря на разные цены акций.
Выход:
2018-02-15 10:30:00, BUY ORDER PLACED, Price: 169.79, Cost: 0.00, Comm: 0.00
2018-02-15 10:30:00, BUY ORDER EXECUTED, Price: 172.06, Cost: 172.06, Comm: 0.17
2018-03-19 14:30:00, SELL ORDER PLACED, Price: 174.19, Cost: 0.00, Comm: 0.00
2018-03-19 14:30:00, SELL ORDER EXECUTED, Price: 174.88, Cost: 172.06, Comm: 0.17
Выше мы видим, что покупка была исполнена в 172.06 (стоимость сделки (то есть стоимость) является той же самой, что и при торговле 1 акцией), однако, ордер на продажу был исполнен по другой цене (174.88), но все еще имеет ту же стоимость сделки и комиссию?
Пример кода:
class Test(bt.SignalStrategy):
def __init__(self):
self.sma1 = bt.ind.SMA(period=100)
self.dataclose= self.datas[0].close
self.order = None
self.buyprice = None
self.buycomm = None
self.sellprice = None
self.sellcomm = None
def log(self, txt, dt=None):
dt = dt or self.data.datetime.datetime(0)
print('%s, %s' % (dt, txt))
def notify_order(self, order):
# 1. If order is submitted/accepted, do nothing
if order.status in [order.Submitted, order.Accepted]:
return
# 2. If order is buy/sell executed, report price executed
if order.status in [order.Completed]:
if order.isbuy():
self.log('BUY ORDER PLACED, Price:{0:8.2f}, Cost:{1:8.2f}, Comm:{2:8.2f}'.format(order.created.price,order.created.value,order.created.comm))
self.log('BUY ORDER EXECUTED, Price:{0:8.2f}, Cost:{1:8.2f}, Comm:{2:8.2f}'.format(order.executed.price,order.executed.value,order.executed.comm))
self.buyprice = order.executed.price
self.buycomm = order.executed.comm
if order.issell():
self.log('SELL ORDER PLACED, Price:{0:8.2f}, Cost:{1:8.2f}, Comm:{2:8.2f}'.format(order.created.price,order.created.value,order.created.comm))
self.log('SELL ORDER EXECUTED, Price:{0:8.2f}, Cost:{1:8.2f}, Comm:{2:8.2f}'.format(order.executed.price, order.executed.value,order.executed.comm))
self.sellprice = order.executed.price
self.sellcomm = order.executed.comm
self.bar_executed = len(self) #when was trade executed
# 3. If order is canceled/margin/rejected, report order canceled
elif order.status in [order.Canceled, order.Margin, order.Rejected]:
self.log('Order Canceled/Margin/Rejected')
self.order = None
def next(self):
if self.order:
return
if self.getposition(data=self.data).size == 0:
if data.close[0] > self.sma1:
self.buy()
else:
if data.close[0] < self.sma1:
self.close()