在这个例子中,我们先看看 list.sort() 的用法,然后再继续。在这里,我们创建了一个列表并使用 sort() 方法按升序排序 -
# Creating a List myList = ["Jacob", "Harry", "Mark", "Anthony"] # Displaying the List print("List = ",myList) # Sort the Lists in Ascending Order myList.sort() # Display the sorted List print("Sort (Ascending Order) = ",myList)
List = ['Jacob', 'Harry', 'Mark', 'Anthony'] Sort (Ascending Order) = ['Anthony', 'Harry', 'Jacob', 'Mark']
在性能更重要的情况下,仅仅为了排序而复制列表不会被认为是好的,而且是浪费。因此,list.sort() 对列表进行就地排序。此方法不返回排序列表。这样,当您需要排序的副本但还需要保留未排序的版本时,您就不会被欺骗而意外覆盖列表。
使用内置的sorted()函数返回一个新列表。此函数根据提供的可迭代对象创建一个新列表,对其进行排序并返回它。
我们现在已经使用sorted()方法对字典列表进行排序。
# List of dictionaries d = [ {"name" : "Sam", "marks" : 98}, {"name" : "Tom", "marks" : 93}, {"name" : "Jacob", "marks" : 97} ] # Display the Dictionary print("Dictionary = \n",d) # Sorting using values with the lambda function print("Sorted = \n",sorted(d, key = lambda item: item['marks']))
('Dictionary = \n', [{'name': 'Sam', 'marks': 98}, {'name': 'Tom', 'marks': 93}, {'name': 'Jacob', 'marks': 97}]) ('Sorted = \n', [{'name': 'Tom', 'marks': 93}, {'name': 'Jacob', 'marks': 97}, {'name': 'Sam', 'marks': 98}])
以上是为什么在Python中list.sort()不会返回已排序的列表?的详细内容。更多信息请关注PHP中文网其他相关文章!