在 python 3.x 中,不推薦使用比較器。相反,Python 依賴于一個key函數(shù),為每個元素分配一個鍵值并使用這些鍵進(jìn)行排序。但是,當(dāng)有一種復(fù)雜的方法來確定一個元素是否應(yīng)該出現(xiàn)在另一個元素之前時,這就是一個問題。示例:一組字符串應(yīng)按字母順序排序,但如果字符串的第一個字母是,則x它應(yīng)該排在第一位。例如:a, b, xaaa, c, xbbb, bxa, bax應(yīng)該排序為xaaa, xbbb, a, b, bax, bxa, c.請問這個排序可以用python實現(xiàn)嗎?
1 回答

慕絲7291255
TA貢獻(xiàn)1859條經(jīng)驗 獲得超6個贊
一種可能的解決方案,使用str.startswith
:
lst = ['a', 'b', 'xaaa', 'c', 'xbbb', 'bxa', 'bax'] print(sorted(lst, key=lambda k: (not k.startswith('x'), k)))
印刷:
['xaaa', 'xbbb', 'a', 'b', 'bax', 'bxa', 'c']
添加回答
舉報
0/150
提交
取消