感觉每次需要用到sort() 以及sorted()函数的时候,小脑袋瓜里就会去思考,sort()和sorted()的区别,哪个是改变原列表的呢?
怒来记录一波
sort()函数是list列表中的函数,而sorted()可以对list或者iterator进行排序。
区别:
1、sort()只能应用在列表list上,而sorted可以对所有可迭代的对象进行排序的操作
2、sort方法会在原list上直接进行排序,不会创建新的list。而sorted方法不会对原来的数据做任何改动,排序后的结果是新生成的。如果我们不需要原来的数据而且数据是list类型,可以用sort方法,能够节省空间。否则要用sorted方法。
用sort函数对列表排序时会影响列表本身,而sorted不会
l1=[1,3,2]
l2=[1,3,2]
l1.sort()
sorted(l2)
print(l1) #[1, 2, 3]
print(l2) #[1, 3, 2]
print(sorted(l2)) #[1, 2, 3]
def sort(self, key=None, reverse=False): # real signature unknown; restored from __doc__ """ L.sort(key=None, reverse=False) -> None -- stable sort *IN PLACE* """ pass
sorted(iterable, key=None, reverse=False)
-
reverse是一个布尔值。如果设置为True,列表元素将被倒序排列,默认为False
-
key接受一个函数,这个函数只接受一个元素,默认为None