为什么在Python中list.sort()不会返回已排序的列表?
示例
在这个例子中,我们先看看 list.sort() 的用法,然后再继续。在这里,我们创建了一个列表并使用 sort() 方法按升序排序 -
# Creating a ListmyList = ["Jacob", "Harry", "Mark", "Anthony"]# Displaying the Listprint("List = ",myList)# Sort the Lists in Ascending OrdermyList.sort()# Display the sorted Listprint("Sort (Ascending Order) = ",myList)
输出
List = ['Jacob', 'Harry', 'Mark', 'Anthony']Sort (Ascending Order) = ['Anthony', 'Harry', 'Jacob', 'Mark']
在性能更重要的情况下,仅仅为了排序而复制列表不会被认为是好的,而且是浪费。因此,list.sort() 对列表进行就地排序。此方法不返回排序列表。这样,当您需要排序的副本但还需要保留未排序的版本时,您就不会被欺骗而意外覆盖列表。
使用内置的sorted()函数返回一个新列表。此函数根据提供的可迭代对象创建一个新列表,对其进行排序并返回它。
使用sorted()根据值对字典列表进行排序
示例
我们现在已经使用sorted()方法对字典列表进行排序。
立即学习“Python免费学习笔记(深入)”;
# List of dictionariesd = [ {"name" : "Sam", "marks" : 98}, {"name" : "Tom", "marks" : 93}, {"name" : "Jacob", "marks" : 97}]# Display the Dictionaryprint("Dictionary = ",d)# Sorting using values with the lambda functionprint("Sorted = ",sorted(d, key = lambda item: item['marks']))
输出
('Dictionary = ', [{'name': 'Sam', 'marks': 98}, {'name': 'Tom', 'marks': 93}, {'name': 'Jacob', 'marks': 97}])('Sorted = ', [{'name': 'Tom', 'marks': 93}, {'name': 'Jacob', 'marks': 97}, {'name': 'Sam', 'marks': 98}])