Предположим, следующее df:
df = pd.DataFrame(
{
'col 1': ['A', 'A', 'B', 'B', 'C'],
'col 2': ['c2', 'd2', 'e2', 'f2', 'g2'],
'col 3': ['c3', 'd3', 'e3', 'f3', 'g3'],
'col 4': ['c4', 'd4', 'e4', 'f4', 'g4'],
}
)
Желаемый результат:
col 1 col 2 col 3
A c2;d2 c3;d3
B e2;f2 e3;f3
C g2 g3
Мне удалось сделать это следующим образом:
df = df.groupby('col 1').transform( lambda x: ';'.join(x)).drop_duplicates()
Проблема в том, что этот метод не сохраняет столбец 1, который мне действительно нужен.и я не мог заставить работать apply
.Я пробовал вот так, но после этого ничего не получается. groupby
.
apply(lambda x: '*'.join(x.dropna().values.tolist()), axis=1)