我有一个数据框,我想重新排序。但是我无法得到想要的桌子形式
df =
id_easy latitude longitude
1 45.0714 7.6187
1 45.0739 7.6195
3 45.0745 7.6152
3 45.0833 7.6145
2 45.0946 7.6194
所需的输出:
1 2 3
45.0714 7.6187 45.0946 7.6194 45.0745 7.6152
45.0739 7.6195 45.0946 7.6194
我试过了:
df_pivot = pd.pivot_table(df,columns = ['id_easy'], values = ['longitude','latitude'])
最佳答案
您可以使用GroupBy.cumcount
进行计数,然后使用pivot
,也可以将MultiIndex
展平使用f-string
:
df['g'] = df.groupby('id_easy').cumcount()
df = (df.pivot(index='g', columns='id_easy', values=['longitude','latitude'])
.sort_index(axis=1, level=1))
df.columns = [f'{a}_{b}' for a, b in df.columns]
print (df)
latitude_1 longitude_1 latitude_2 longitude_2 latitude_3 longitude_3
g
0 45.0714 7.6187 45.0946 7.6194 45.0745 7.6152
1 45.0739 7.6195 NaN NaN 45.0833 7.6145
或将
set_index
与unstack
一起使用(也适用于较早的熊猫版本):df['g'] = df.groupby('id_easy').cumcount()
df = df.set_index(['g','id_easy']).unstack().sort_index(axis=1, level=1)
df.columns = [f'{a}_{b}' for a, b in df.columns]
print (df)
latitude_1 longitude_1 latitude_2 longitude_2 latitude_3 longitude_3
g
0 45.0714 7.6187 45.0946 7.6194 45.0745 7.6152
1 45.0739 7.6195 NaN NaN 45.0833 7.6145
关于python - 用数据透视表排序,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/57670884/