Возникли проблемы при создании фрейма данных транзакции. - PullRequest
0 голосов
/ 27 сентября 2019

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

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

Ошибки и текущий вывод Tdf.tail Empty DataFrame Columns: [Buy, Sell, Profit] Index: [] single positional indexer is out-of-bounds

как выглядит df

timestamp Price decide 2019-08-19 3.0000 1.0 2019-08-20 2.6200 0.0 2019-08-21 2.3200 0.0 2019-08-22 2.1400 0.0 2019-08-23 1.9500 -1.0

Price = [['2019-08-19',3.0000,1.0],['2019-08-20',2.6200,0.0],['2019-08-21',2.3200,0.0],['2019-08-22',2.1400,0.0],['2019-08-23',1.9500,-1.0]]
df = pd.DataFrame(Price,columns = ['timestamp','Price','decide'])
df.set_index('timestamp',inplace=True)
Trades = []
Tdf = pd.DataFrame(Trades,columns = ['Buy','Sell','Profit'])

for y in df.index.values:#Buy = 1.0 , Sell = -1.0
    if df['decide'].iloc[y] == 1.0:
        Tdf.append({'Buy' : df['Price'][y]},ignore_index=True)

    if df['decide'].iloc[y] == -1.0:
        profit =  df['Price'].iloc[y] - Tdf['Buy'].iloc[-1]
        Tdf.at[-1,'Sell'] = df['Price'].iloc[y]
        Tdf.at[-1,'Profit'] = profit

Ожидается, что Tdf будет выглядеть как buy sell profit 0 3.00 1.95 -1.05

1 Ответ

0 голосов
/ 30 сентября 2019

Вот что мне нужно было сделать:

df = df[-30:]
df.reset_index(inplace=True)
try:
    for y in df.index.values:

         if y == 0 and df['buy_sell'].iloc[y] == 1.0:
            Tdf.at[y,'Buy'] = df['Price'].iloc[y]
            buyIndex = y

         if df['buy_sell_hold'].iloc[y] == 1.0:
            Tdf.at[y,'Buy'] = df['Price'].iloc[y]
            buyIndex = y

         if y == 0 and df['buy_sell_hold'].iloc[y] == -1.0:
            print('sold something we did not buy')

         elif df['buy_sell_hold'].iloc[y] == -1.0:
            profit = df['Price'].iloc[y] - Tdf['Buy'].iloc[-1]
            Tdf.at[buyIndex,'Sell'] = df['Price'].iloc[y]
            Tdf.at[buyIndex,'Profit'] = profit
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...