sort() 是Python列表的一个内置的排序方法,list.sort() 方法排序时直接修改原列表,返回None;

sort() 是Python内置的一个排序函数,它会从一个迭代器返回一个排好序的新列表。

相比于 sort(),sorted() 使用的范围更为广泛,但是如果不需要保留原列表,sort更有效一点。另外,sort() 只是列表的一个方法,只适用于列表,而sorted() 函数接受一切迭代器,返回新列表。

两者的函数形式分别如下(Python3.5.2):

sorted(iterable[, key][, reverse])

list.sort(*, key=None, reverse=None)

这两个方法有以下 2 个共同的参数:

key 是带一个参数的函数,返回一个值用来排序,默认为 None。这个函数只调用一次,所以fast。

reverse 表示排序结果是否反转

看例子:

>>> a = (1,2,4,2,3) # a 是元组,故不能用sort() 排序

>>> a.sort()

Traceback (most recent call last):

File "", line 1, in

AttributeError: 'tuple' object has no attribute 'sort'

>>> sorted(a) # sorted() 可以为元组排序,返回一个新有序列表

[1, 2, 2, 3, 4]

>>> a=['1',1,'a',3,7,'n']

>>> sorted(a)

[1, 3, 7, '1', 'a', 'n']

>>> a # sorted() 不改变原列表

['1', 1, 'a', 3, 7, 'n']

>>> print a.sort()

None

>>> a # a.sort()直接修改原列表

[1, 3, 7, '1', 'a', 'n']

因此如果实际应用过程中需要保留原有列表,使用 sorted() 函数较为适合,否则可以选 择 sort() 函数,因为 sort() 函数不需要复制原有列表,消耗的内存较少,效率也较高。

sorted() 函数功能非常强大,它可以方便地针对不同的数据结构进行排序,从而满足不同需求。例子如下:

对字典进行排序

>>> sorted({1: 'D', 2: 'B', 3: 'B', 4: 'E', 5: 'A'}) # 根据字典键排序

[1, 2, 3, 4, 5]

>>> sorted({1: 'D', 2: 'B', 3: 'B', 4: 'E', 5: 'A'}.values()) # 根据字典值排序

['A', 'B', 'B', 'D', 'E']

对多维列表排序

>>> student_tuples = [('john', 'A', 15),('jane', 'B', 12),('dave', 'B', 10)]

>>> sorted(student_tuples, key = lambda student: student[0]) # 对姓名排序

[('dave', 'B', 10), ('jane', 'B', 12), ('john', 'A', 15)]

>>> sorted(student_tuples, key = lambda student: student[2]) # 年龄排序

[('dave', 'B', 10), ('jane', 'B', 12), ('john', 'A', 15)]

调用operator模块中的 itemgetter() 可以实现根据多个参数排序:

>>> sorted(student_tuples, key = itemgetter(2)) # 根据年龄排序

[('dave', 'B', 10), ('jane', 'B', 12), ('john', 'A', 15)]

>>> sorted(student_tuples, key = itemgetter(1, 2)) # 根据成绩和年龄排序

[('john', 'A', 15), ('dave', 'B', 10), ('jane', 'B', 12)]

>>> sorted(student_tuples, key = itemgetter(1, 2), reverse=True) # 反转排序结果

[('jane', 'B', 12), ('dave', 'B', 10), ('john', 'A', 15)]

ps: itemgetter 返回一个函数,实现取元素的功能。比如

f = itemgetter(2),调用 f(r) 返回 r[2];

f = itemgetter(2, 5, 3),调用 f(r) 返回元组 (r[2], r[5], r[3]).

python 数组排序sort_Python之排序函数sort() 和 sorted()相关推荐

  1. 排序函数(sort()、sorted()、argsort()函数)

    python的内建排序函数有 sort.sorted两个. 1.基础的序列升序排序直接调用sorted()方法即可 1 ls = list([5, 2, 3, 1, 4]) 2 new_ls = so ...

  2. 排序函数 sort()、sorted()、argsort()函数

    sort()函数 python的内建排序函数有 sort.sorted两个.而sort ()可以直接对列表进行排序 用法:list.sort(func=None, key=None, reverse= ...

  3. python数组排序方法详解(sort, sorted,argsort)

    这三个排序方法应对日常工作基本够用 先说一下三者的区别 sort, sorted 是用在 list 数据类型中的排序方法 argsort 是用在 numpy 数据类型中的排序方法( numpy 里也有 ...

  4. 【Python】排序函数 sort、sorted 对复杂列表排序

    1 lambda 表达式 匿名函数. 匿名函数lambda:是指一类无需定义标识符(函数名)的函数或子程序. lambda 函数可以接收任意多个参数 (包括可选参数) 并且返回单个表达式的值. lam ...

  5. python排序之sort和sorted

    python排序之sort和sorted 在使用python的时候很多时候需要用到排序操作,自己挨个去排太麻烦,而且效率也比较低下.因此学会使用Python自带的排序函数就显得尤为必要了. pytho ...

  6. python字典sort_python字典排序

    引子 字典,形如 dic = {'a':1 , 'b':2 , 'c': 3},字典中的元素没有顺序,所以dic[0]是有语法错误的.并且不可以有重复的键值,所以 dic.add['c'] = 4后, ...

  7. R语言数据排序函数sort, order rank实战

    R语言数据排序函数sort, order & rank实战 目录 R语言数据排序函数sort, order & rank实战 #sort vs. order vs. rank函数基础 ...

  8. C++ 排序函数 sort(),qsort()的用法

    想起来自己天天排序排序,冒泡啊,二分查找啊,结果在STL中就自带了排序函数sort,qsort,总算把自己解脱了~ 所以自己总结了一下,首先看sort函数见下表: 函数名 功能描述 sort 对给定区 ...

  9. python 排序函数 sort sorted 简介

    sort() 是Python列表的一个内置的排序方法,list.sort() 方法排序时直接修改原列表,返回None: sort() 是Python内置的一个排序函数,它会从一个迭代器返回一个排好序的 ...

最新文章

  1. iPhone开发:Objective-c中@property声明时的参数释疑
  2. linux find命令的日常使用
  3. [蓝桥杯][算法提高VIP]密码锁(BFS)
  4. [EDA]FPGA/CPLD 设计流程步骤及步骤概念
  5. golang中apend_golang的append()为什么不会影响slice的地址?
  6. ASP.NET 2.0 Internet安全之参考实现
  7. 点击按钮,文本框如何不失去焦点
  8. Elasticsearch 7.9.3 发布
  9. Shell脚本中的分号使用
  10. HTML实现复制功能
  11. TCPDF支持php7,php – 我不能要求tcpdf库
  12. 红帽linux系统安装指导
  13. linux 网络检测工具有哪些,Linux系统下常用的网络测速工具有哪些
  14. 国内汽车车载电源DCDC首家,硬件原理图,软件源码
  15. 图像Randon变换含Matlab源码
  16. centos7搭建单机kafka,开启SASL/PLAIN加密,并使用kafka tool 登录
  17. 【数据库系统】考虑题4所示的日志记录,假设开始时A、B、C的值都是0 (1) 如果系统故障发生在14之后,写出系统恢复后A、B、C的值
  18. linux 效果器软件下载,盘点丨15款免费又好用的音乐制作软件
  19. SQL查询,子查询作为结果字段
  20. vue重复点击路由报错,解决NavigationDuplicated: Avoided redundant navigation to current location: 问题

热门文章

  1. 模式识别 实验四 手写数字识别的神经网络算法设计与实现
  2. 数据恢复与数据彻底删除
  3. 什么是指针以及如何动态申请空间
  4. Goby在护网中的应用
  5. NVM(非易失存储介质)在索引结构中的机遇与挑战(未完,整理中...)
  6. 58.创建线程CreateProcess、STARTUPINFO、PROCESS_INFORMATION、ExitProcess、TerminateProcess、GetCommandLine、Get
  7. 专业应用软件随身带,一招助您轻松搞定客户
  8. 修改注册表后不重启计算机,修改注册表后不重启计算机边生效(转)
  9. 张学友MTV全集[DVD]
  10. ajax用到的js,PJBLOG中用到的ajaxjs.几个简单的函数分享