python中有两种列表排序的方法,即sort() 和sorted() 。这两个方法看起来很像,但是有很大的差别。sort() 修改原列表,永久性排序,无返回值,内存消耗小,而sorted() 保持原列表不变,临时性排序,有返回值,内存消耗大。本文向大家详解这二者使用的区别。
一、sort()
1、定义:python列表的一个内置的排序方法,只是列表的一个方法,只适用于列表;
2、作用:作用于列表,直接修改原有列表,无返回值;
3、排序时间:对列表进行永久性排序;
4、内存消耗:无需保存原对象,节省内存空间。
5、使用实例:
list_name = [1, 3, 4, -0.2200222, -4.66]
list_name.sort()
print(list_name)
输出
[-4.66, -0.2200222, 1, 3, 4]
原列表的值发生变化,原列表被修改
二、sorted()
1、定义:python内置的一个排序函数,接受一切迭代器,返回一个有序的副本,并且类型总是列表;
2、作用:作用于任意可迭代的对象,原有列表保持不变,会返回一个排序后的列表。
3、排序时间:对列表进行临时排序。
4、内存消耗:返回新对象,所以耗费较多资源。
5、使用实例:
list_name = [1, 3, 4, -0.2200222, -4.66]
list_name_new = sorted(list_name)
print(list_name)
print(list_name_new)
输出
[1, 3, 4, -0.2200222, -4.66] 原列表
[-4.66, -0.2200222, 1, 3, 4] 排序后的列表
相比于sort(),sorted() 使用的范围更为广泛,但是sort()消耗内存比较小,效率也比较高。所以如果不需要保留原列表,sort更有效一点哦~
声明:本网站尊重并保护知识产权,根据《信息网络传播权保护条例》,如果用户发布的作品侵犯了您的权利,请联系管理员:wupeng@hqwx.com
环球青藤
官方QQ群扫描上方二维码或点击一键加群,免费领取大礼包,加群暗号:青藤。 一键加群