最近在工作中遇到一个问题,就是需要对一列中文字符按照后面的数字排序,但是排序的结果往往是这样的:
原序列:(版本为:python 3.8.1,pandas: 1.0.3)
A列
中国1
俄罗斯2
美国11
加拿大12
英国3
想排序为:
中国1
俄罗斯2
英国3
美国11
加拿大12
但pandas 用 sort_values()的结果是:
中国1
美国11
加拿大12
俄罗斯2
英国3
查了很多资料无法解决。
最后只能用笨办法
分成两列
然后给数字列0-9的个位数前填0,9以上不管;
最后再把两列合并
得到如下结果,就是自己想要的了。
中国01
俄罗斯02
英国03
美国11
加拿大12
不知道各位大神谁有更好的办法?请赐教!