Я пытаюсь очистить свой фрейм данных, чтобы создать график, показывающий прибыль с течением времени. Я сгруппировал свой фрейм данных по Symbol
, думая, что будет легче правильно применить анализ, но я не уверен в логике c отсюда. Я хотел бы создать отдельный фрейм данных, как в примере ниже.
Код:
import pandas as pd
data = {'Action': ['BUY_TO_OPEN', 'SELL_TO_CLOSE', 'BUY_TO_OPEN', 'SELL_TO_CLOSE', 'BUY_TO_OPEN', 'SELL_TO_CLOSE', 'BUY_TO_OPEN', 'SELL_TO_CLOSE', 'BUY_TO_OPEN', 'SELL_TO_CLOSE'],
'Date': ['2020-07-23', '2020-07-29', '2020-06-04', '2020-06-24', '2020-07-17', '2020-07-21', '2020-05-28', '2020-05-28', '2020-06-29', '2020-07-20'],
'Quantity': [200.0, 200.0, 130.0, 130.0, 100.0, 100.0, 100.0, 100.0, 120.0, 120.0],
'Symbol': ['ACHV', 'ACHV', 'ACST', 'ACST', 'AGE', 'AGE', 'AIKI', 'AIKI', 'AIKI', 'AIKI'],
'tot_value': [-96.16, 163.81, -100.2, 83.07, -100.08, 149.9, -74.08, 71.91, -100.9, 153.48]}
df_trade = pd.DataFrame(data)
df_trade.Date = pd.to_datetime(df_trade.Date)
df_trades = pd.pivot_table(df_trades, index=['Symbol', 'Date', 'Action', 'Quantity'], values=['tot_value'])
print(df_trades)
Сводная таблица:
tot_value
Symbol Date Action Quantity
ACHV 2020-07-23 BUY_TO_OPEN 200.0 -96.16
2020-07-29 SELL_TO_CLOSE 200.0 163.81
ACST 2020-06-04 BUY_TO_OPEN 130.0 -100.20
2020-06-24 SELL_TO_CLOSE 130.0 83.07
AGE 2020-07-17 BUY_TO_OPEN 100.0 -100.08
2020-07-21 SELL_TO_CLOSE 100.0 149.90
AIKI 2020-05-28 BUY_TO_OPEN 100.0 -74.08
SELL_TO_CLOSE 100.0 71.91
2020-06-29 BUY_TO_OPEN 120.0 -100.90
2020-07-20 SELL_TO_CLOSE 120.0 153.48
Пример фрейма данных, который я пытаюсь получить:
Где дата - это дата SELL_TO_CLOSE
, а столбец Profit
- это сумма tot_value
используя для расчета каждую пару BUY_TO_OPEN
и SELL_TO_CLOSE
.
Symbol Date Profit
ACHV 2020-07-29 67.65
ACST 2020-06-24 -17.13
AGE 2020-07-21 49.82
AIKI 2020-05-28 -2.17
AIKI 2020-07-20 52.58