是否有更多的Pythonic,紧凑,直观的方式对字母等级进行排序(不使用自定义字典)?
grades = ['B-','C','B','C+','A','D+','B+','C-','A+','D','A-']
sorted(grades, key=lambda g: (g[0], '+ -'.index((g+' ')[1])) )
['A+', 'A', 'A-', 'B+', 'B', 'B-', 'C+', 'C', 'C-', 'D+', 'D']
为了获得' X - ',' X',' X +'的比较数字顺序,我做了一个hacky append of a空间' '因此g[1]
始终存在,因此我可以使用.index()
来获取修饰符的等级' + - '。
(由this question激励)
答案 0 :(得分:4)
没有
modmap = {
'-': 0,
'': 1,
'+': 2
}
print(sorted(grades, key=lambda x: (-ord(x[0]), modmap[x[1:]])))
答案 1 :(得分:1)
是吗?
>>> sorted(grades, key=lambda g: g + ',')
['A+', 'A', 'A-', 'B+', 'B', 'B-', 'C+', 'C', 'C-', 'D+', 'D']
明显更紧凑,我想说也是pythonic,只是不是很直观:-P
成功是因为'+' < ',' < '-'
。
另一个:
>>> sorted(grades, key=lambda g: (g[0], ' -'.find(g[1:])))
['A+', 'A', 'A-', 'B+', 'B', 'B-', 'C+', 'C', 'C-', 'D+', 'D']
在+
中找不到后缀' -'
,因此find
返回-1
。空后缀为0
,后缀-
为1
。