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

慕絲7291255
TA貢獻1859條經驗 獲得超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
提交
取消