Я пытаюсь добавить два двух столбца в Pandas DataFrame - один, который будет представлять значение следующих недель, а другой - сумму следующих 4 недель.
Пример существующего DataFrame можетбудет видно ниже.Приведенный ниже DataFrame является лишь кратким фрагментом всего DataFrame, который охватывает несколько лет.Приведенный ниже DataFrame был получен с использованием следующей функции: df = df.groupby([pd.Grouper(key='date', freq='W'), pd.Grouper('company_name').agg({'returns': 'sum'})
date company_name returns
2014-12-07 Amazon -0.5
2014-12-14 Amazon -0.1
2014-12-21 Amazon 0.5
2014-12-28 Amazon 0.3
2015-01-04 Amazon 0.1
2014-12-07 Facebook 0.5
2014-12-14 Facebook 0.5
2014-12-21 Facebook 0.5
2014-12-28 Facebook -0.5
2015-01-04 Facebook -0.5
2014-12-07 Google 0.1
2014-12-14 Google 0.1
2014-12-21 Google 0.1
2014-12-28 Google 0.1
2015-01-04 Google 0.1
2014-12-07 Intel 0.2
2014-12-14 Intel 0.2
2014-12-21 Intel 0.2
2014-12-28 Intel 0.2
2015-01-04 Intel 0.2
Требуемый вывод вернет значение для следующей недели и сумму следующих 4 недель, начиная со столбца «дата».Пример желаемого результата можно увидеть ниже.
date company_name returns next_week_return next_month_return
2014-12-07 Amazon -0.5 -0.5 0.8
2014-12-14 Amazon -0.1 0.5 0.8
2014-12-21 Amazon 0.5 0.3 0.8
2014-12-28 Amazon 0.3 0.1 0.8
2015-01-04 Amazon 0.1 0.1 ...
2014-12-07 Facebook 0.5 0.5 0.0
2014-12-14 Facebook 0.5 0.5 0.0
2014-12-21 Facebook 0.5 -0.5 0.0
2014-12-28 Facebook -0.5 -0.5 0.0
2015-01-04 Facebook -0.5 0.1 ...
2014-12-07 Google 0.1 0.1 0.4
2014-12-14 Google 0.1 0.1 0.4
2014-12-21 Google 0.1 0.1 0.4
2014-12-28 Google 0.1 0.1 0.4
2015-01-04 Google 0.1 0.1 ...
2014-12-07 Intel 0.2 0.2 0.8
2014-12-14 Intel 0.2 0.2 0.8
2014-12-21 Intel 0.2 0.2 0.8
2014-12-28 Intel 0.2 0.2 0.8
2015-01-04 Intel 0.2 0.2
Ниже приведен фрагмент исходного CSV.
date CompanyName return
07/12/2014 8x8 Inc -0.0038835
14/12/2014 8x8 Inc 0.036923354
21/12/2014 8x8 Inc 0.108854405
28/12/2014 8x8 Inc 0.042793145
04/01/2015 8x8 Inc -0.027219971
11/01/2015 8x8 Inc -0.038249882
18/01/2015 8x8 Inc 0.045946457
25/01/2015 8x8 Inc -0.107796707
01/02/2015 8x8 Inc -0.056725981
08/02/2015 8x8 Inc 0.024344572
15/02/2015 8x8 Inc 0.00756624
22/02/2015 8x8 Inc -0.04365263
01/03/2015 8x8 Inc -0.02794593
08/03/2015 8x8 Inc -0.039922714
15/03/2015 8x8 Inc 0.020848566
22/03/2015 8x8 Inc 0.116712617
29/03/2015 8x8 Inc 0.028952565
05/04/2015 8x8 Inc 0.053253322
12/04/2015 8x8 Inc -0.006787356
19/04/2015 8x8 Inc -0.00912207
26/04/2015 8x8 Inc 0.013652089
03/05/2015 8x8 Inc -0.021702736
10/05/2015 8x8 Inc -0.021004273
17/05/2015 8x8 Inc 0.012888286
24/05/2015 8x8 Inc -0.021177262
31/05/2015 8x8 Inc -0.027630051
07/12/2014 AB SA -1.015859196
14/12/2014 AB SA -0.01810143
21/12/2014 AB SA -0.073869849
28/12/2014 AB SA 0.000666445
04/01/2015 AB SA 0.051293294
11/01/2015 AB SA 0.004735605
18/01/2015 AB SA 0.014073727
25/01/2015 AB SA 0.097002705
01/02/2015 AB SA 0.00337648
08/02/2015 AB SA 0.018093743
15/02/2015 AB SA 0.019667392
22/02/2015 AB SA 0.024844339
01/03/2015 AB SA 0.015707129
08/03/2015 AB SA 0.109611209
15/03/2015 AB SA -0.039164849
22/03/2015 AB SA -0.002909093
29/03/2015 AB SA 0.007256926
05/04/2015 AB SA -0.025385791
12/04/2015 AB SA 0.019584469
19/04/2015 AB SA -0.01342302
26/04/2015 AB SA 0.073405725
03/05/2015 AB SA -0.018666287
10/05/2015 AB SA 0.019350984
17/05/2015 AB SA -0.030814439
24/05/2015 AB SA 0.027386256
31/05/2015 AB SA -0.033285978
07/12/2014 ACCO Brands Corp 0.432332004
14/12/2014 ACCO Brands Corp -0.064822249
21/12/2014 ACCO Brands Corp 0.010163837
28/12/2014 ACCO Brands Corp 0.022223137
04/01/2015 ACCO Brands Corp -0.034659702
11/01/2015 ACCO Brands Corp -0.026514522
18/01/2015 ACCO Brands Corp -0.018868484
25/01/2015 ACCO Brands Corp 0.013010237
01/02/2015 ACCO Brands Corp -0.071850737
08/02/2015 ACCO Brands Corp 0.00126183
15/02/2015 ACCO Brands Corp -0.016000601
22/02/2015 ACCO Brands Corp -0.01420295
01/03/2015 ACCO Brands Corp -0.010457612
08/03/2015 ACCO Brands Corp -0.006591982
15/03/2015 ACCO Brands Corp -0.008257798
22/03/2015 ACCO Brands Corp 0.039272062
29/03/2015 ACCO Brands Corp 0.035312622
05/04/2015 ACCO Brands Corp 0.012315427
12/04/2015 ACCO Brands Corp 0.037241541
19/04/2015 ACCO Brands Corp -0.025075941
26/04/2015 ACCO Brands Corp -0.010535083
03/05/2015 ACCO Brands Corp -0.044016885
10/05/2015 ACCO Brands Corp -0.013845407
17/05/2015 ACCO Brands Corp 0.005056901
24/05/2015 ACCO Brands Corp -0.024251348
31/05/2015 ACCO Brands Corp -0.051701374
07/12/2014 Acer Inc 3.829777429
07/12/2014 Acer Inc -3.46435286
14/12/2014 Acer Inc 0.042160811
14/12/2014 Acer Inc 0.021342273
21/12/2014 Acer Inc -0.056618894
21/12/2014 Acer Inc -0.046304568
28/12/2014 Acer Inc 0.033415997
28/12/2014 Acer Inc 0.062759689
04/01/2015 Acer Inc 0.002344667
04/01/2015 Acer Inc -0.004460974
11/01/2015 Acer Inc 0.082988363
11/01/2015 Acer Inc 0.093933758
18/01/2015 Acer Inc -0.033983853
18/01/2015 Acer Inc -0.042689409
25/01/2015 Acer Inc 0.017136282
25/01/2015 Acer Inc -0.012539349
01/02/2015 Acer Inc 0.002424244
01/02/2015 Acer Inc 0.010980502
08/02/2015 Acer Inc -0.014634408
08/02/2015 Acer Inc -0.015723594
15/02/2015 Acer Inc -0.014851758
15/02/2015 Acer Inc 0.025040432
22/02/2015 Acer Inc 0
22/02/2015 Acer Inc 0.022919261
01/03/2015 Acer Inc 0.024631787
01/03/2015 Acer Inc -0.007581537
08/03/2015 Acer Inc 0.05445132
08/03/2015 Acer Inc 0.027028672
15/03/2015 Acer Inc -0.023311079
15/03/2015 Acer Inc -0.022472856
22/03/2015 Acer Inc -0.002361276
22/03/2015 Acer Inc 0
29/03/2015 Acer Inc -0.021506205
29/03/2015 Acer Inc 0.012048339
05/04/2015 Acer Inc -0.021978907
05/04/2015 Acer Inc -0.028109292
12/04/2015 Acer Inc -0.004950505
12/04/2015 Acer Inc 0.02756683
19/04/2015 Acer Inc -0.007472015
19/04/2015 Acer Inc 0.003016594
26/04/2015 Acer Inc 0.009950331
26/04/2015 Acer Inc 0.006006024
03/05/2015 Acer Inc -0.004962789
03/05/2015 Acer Inc 0.002989539
10/05/2015 Acer Inc -0.040614719
10/05/2015 Acer Inc -0.087282784
17/05/2015 Acer Inc -0.064193158
17/05/2015 Acer Inc -0.072605718
24/05/2015 Acer Inc 0.008253142
24/05/2015 Acer Inc -0.032031208
31/05/2015 Acer Inc 0.005464494
31/05/2015 Acer Inc 0.057961788
Исходя из вышесказанного, я хотел бы добавить два столбца в каждую строку - один next_week_return
, в котором будут показаны данные о доходах для следующих компаний за следующие недели;и другой: next_month_return
, который будет суммой возвращения за следующие четыре недели.
Буду очень признателен за любую помощь, которую может оказать каждый.