首页 > 解决方案 > 为什么 sorted 不能正确排序数组?

问题描述

我正在尝试使用 sorted 按其第 4 个值从最大到最小对 2d 数组进行排序,但由于某种原因,它没有正确排序。似乎正确地对两个值进行了排序,但仅此而已。我试图在互联网上查看如何使用 sorted 但似乎这应该正确排序:

stuff = [['A', '15', '23', '5'], ['A', '15', '23', '2'], ['A', '15', '23', '17'], ['A', '15', '23', '16'], ['A', '15', '23', '12']]
stuff = sorted(stuff, key=lambda x: x[3], reverse = True)
print(stuff)

这是我得到的输出: [['A', '15', '23', '5'], ['A', '15', '23', '2'], ['A', ' 15', '23', '17'], ['A', '15', '23', '16'], ['A', '15', '23', '12']]

标签: pythonarrayspython-3.xsorting

解决方案


那是因为您的key函数正在比较字符串值。因此,当它尝试与 比较'2''17',它会逐个字符地进行比较,并且由于'2' > '1',它认为它具有更大的价值。

stuff您可以通过在数组第 4 项上使用整数来轻松解决此问题:

stuff = [['A', '15', '23', 5], ['A', '15', '23', 2], ['A', '15', '23', 17], ['A', '15', '23', 16], ['A', '15', '23', 12]]

或者通过调用int键函数从字符串转换为整数:

stuff = sorted(stuff, key=lambda x: int(x[3]), reverse = True)

推荐阅读