Фон
Отсюда изменен следующий код Эффективный способ развернуть (разбить) несколько столбцов списка в пандах DataFrame
Iсоздайте фрейм данных
import pandas as pd
df = pd.DataFrame({'App': ['x1','x2','x3', 'x4'], 'Ban':['v1','v2','v3','v4'], 'C':[['c2'],['c3','c4'],['c5','c6'],['c7','c8']],'D':[['d1','d2'],['d3','d4'],['d5','d6'],['d7','d8']], 'E':[['e1','e2'],['e3','e4'],['e5','e6'],['e7','e8']]})
df
, который выглядит следующим образом
App Ban C D E
0 x1 v1 [c2] [d1, d2] [e1, e2]
1 x2 v2 [c3, c4] [d3, d4] [e3, e4]
2 x3 v3 [c5, c6] [d5, d6] [e5, e6]
3 x4 v4 [c7, c8] [d7, d8] [e7, e8]
Затем я использую следующий код
(df.set_index('Ban')
.apply(lambda x: x.apply(pd.Series).stack())
.reset_index()
.drop('level_1', 1))
, который создает следующее
Ban App C D E
0 v1 x1 c2 d1 e1
1 v1 NaN NaN d2 e2
2 v2 x2 c3 d3 e3
3 v2 NaN c4 d4 e4
4 v3 x3 c5 d5 e5
5 v3 NaN c6 d6 e6
6 v4 x4 c7 d7 e7
7 v4 NaN c8 d8 e8
Желаемый вывод
Это близко к тому, что я хочу.Но мой желаемый результат - это (не NaN
, а вместо этого имя App
и C
:
Ban App C D E
0 v1 x1 c2 d1 e1
1 v1 x1 c2 d2 e2
2 v2 x2 c3 d3 e3
3 v2 x2 c4 d4 e4
4 v3 x3 c5 d5 e5
5 v3 x3 c6 d6 e6
6 v4 x4 c7 d7 e7
7 v4 x4 c8 d8 e8
Вопрос
Как мнеполучить желаемый результат?