比方说我有一个list是这个样子:

[('1',0.99,2,"a"),('2',0.78,17,"b"),('3',0.32,2,'c')]

我现在想把这个list按照里面每个tuple的第三个位置为主要关键字,第二个位置为次要关键字排序。

其实很简单,把sort里面的key写成返回两个compare元素的func就行了:

t = [('1',0.99,2,"a"),('2',0.78,17,"b"),('3',0.32,2,'c')]
key = lambda x:(x[2],x[1])  ## 以每个元素的第3个位置为主要关键字,第2个位置为次要关键字

t.sort(key=key,reverse=True)
print(t)

输出:

[('2', 0.78, 17, 'b'), ('1', 0.99, 2, 'a'), ('3', 0.32, 2, 'c')]

参考:
Is there a way to sort by a second key in the event that the first key is equal?

Logo

GitCode 天启AI是一款由 GitCode 团队打造的智能助手,基于先进的LLM(大语言模型)与多智能体 Agent 技术构建,致力于为用户提供高效、智能、多模态的创作与开发支持。它不仅支持自然语言对话,还具备处理文件、生成 PPT、撰写分析报告、开发 Web 应用等多项能力,真正做到“一句话,让 Al帮你完成复杂任务”。

更多推荐