python sort() 和sorted() 的区别

感觉每次需要用到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

猜你喜欢

转载自blog.csdn.net/xiaolangmin/article/details/88795701