【发布时间】:2017-03-08 01:37:57
【问题描述】:
所以我有一系列 Cabin 值;左侧是索引,右侧列保存 Cabin 值。使用 sort_values 方法后,我只能对值进行部分排序。
x = Cabin_Fare=Cabin_Fare.sort_values(['Cabin' ])
210 A31
186 A32
446 A34
1185 A34
1266 A34
807 A36
97 A
24 A6
175 A7
1058 B10
738 B101
816 B102
1107 B11
330 B18
524 B18
171 B19
691 B20
660 D48
682 D49
626 D50
22 D56
783 D6
276 D7
628 D9
430 E10
718 E101
304 E101
124 E101
461 E12
752 E121
1234 NaN
1252 NaN
1257 NaN
73 NaN
121 NaN
我遇到的问题是尽管能够对舱室字母进行排序,但我无法按舱室字母上的数字进行排序。 所以我想要的输出是
97 A
24 A6
175 A7
210 A31
186 A32
446 A34
1185 A34
1266 A34
807 A36
1058 B10
1107 B11
330 B18
524 B18
171 B19
691 B20
738 B101
816 B102
........
1234 NaN
1252 NaN
1257 NaN
73 NaN
121 NaN
我并不特别关注 NaN 值,但我希望在系列结束时使用它们。如有必要,单独的 Cabin 值(例如单独的“A”)可以添加一个“0”,但我希望没有附加数字的字母排在列表的第一位。
我得到了一些想法,但事实证明这个代码(如下)与字母顺序混淆。我想保留字母顺序。
x.reindex(x[x.notnull()].str[1:].replace('', 0).astype(int).sort_values().index)
谢谢。
【问题讨论】: