Есть ли более питонский, компактный, интуитивно понятный способ сортировки букв по буквам, чем этот (без использования специального слова)?
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 +', я делаю хакерское добавление пробела '', так что g[1]
всегда существует, поэтому я могу использовать .index()
чтобы получить ранг модификатора '+ -'.
(мотивировано этим вопросом )