深入理解python中sort()与sorted()的区别


Posted in Python onAugust 29, 2018

Python list内置sort()方法用来排序,也可以用python内置的全局sorted()方法来对可迭代的序列排序生成新的序列

一,最简单的排序

1.使用sort排序

my_list = [3, 5, 1, 4, 2]
my_list.sort()
print (my_list)
#输出: [1, 2, 3, 4, 5]

使用sort()方法对list排序会修改list本身,不会返回新list.

sort()不能对dict字典进行排序

2.使用sorted()排序

my_list = [3, 5, 1, 4, 2]
result = sorted(my_list)
print (result)
#输出: [1, 2, 3, 4, 5]

my_dict = {"a":"1", "c":"3", "b":"2"}
result = sorted(my_dict)
print (result)
#输出: ['a', 'b', 'c']

sorted()会生成一个新的列表或字典对象,对dict排序默认会按照dict的key值进行排序,最后返回的结果是一个对key值排序好的list

二,key参数

从python2.4开始,list.sort()和sorted()函数增加了key参数来指定一个函数,此函数将在每个元素比较前被调用

key参数的值为一个函数,此函数只有一个参数且返回一个值用来进行比较。这个技术是快速的因为key指定的函数将准确地对每个元素调用。

1.对复杂的元组排序

student_tuples = [
    ('john', 'A', 15),
    ('jane', 'B', 12),
    ('dave', 'B', 10),
]
result = sorted(student_tuples, key=lambda student: student[2])
print (result)
#输出 [('dave', 'B', 10), ('jane', 'B', 12), ('john', 'A', 15)]

以上可以看出排序是按照10, 12, 15值进行排序的,因为函数lambda student:student[2]返回的值分别是10, 12, 15。

所以就用函数返回的值进行比较;key=15 ,key=12,key=10根据这些返回值进行比较;

lambda student:student[2] 等价于
def f(student):
  return student[2]

2.根据字典的value排序

默认sorted是对dict的key排序的,如果要根据dict的value排序就需要指定key参数了

my_dict = {"a":"2", "c":"5", "b":"1"}
result = sorted(my_dict)
print (result)
#默认对dict排序,不指定key参数,会默认对dict的key值进行比较排序
#result输出: ['a', 'b', 'c']
result2 = sorted(my_dict, key=lambda x:my_dict[x])
print (result2)
#指定key参数,根据dict的value排序
#result2输出:['b', 'a', 'c']

扩展用法:

1.Key Function:

从Python2.4开始,list.sort() 和 sorted() 都增加了一个 ‘key' 参数用来在进行比较之前指定每个列表元素上要调用的函数。

例如:

区分大小写的字符串比较排序:

>>> sorted("This is a test string from Andrew".split(), key=str.lower)
['a', 'Andrew', 'from', 'is', 'string', 'test', 'This']

key应该是一个函数,其接收一个参数,并且返回一个用于排序依据的key。其执行效率很高,因为对于输入记录key function能够准确的被调用。

对于复杂的对象,使用对象的下标作为key。

例如:

>>> student_tuples = [
...   ('john', 'A', 15),
...   ('jane', 'B', 12),
...   ('dave', 'B', 10),
... ]
>>> sorted(student_tuples, key=lambda student: student[2])  # sort by age
[('dave', 'B', 10), ('jane', 'B', 12), ('john', 'A', 15)]

使用对象的属性进行操作:

例如:

>>> class Student:
...   def __init__(self, name, grade, age):
...     self.name = name
...     self.grade = grade
...     self.age = age
...   def __repr__(self):
...     return repr((self.name, self.grade, self.age))
>>>
>>> student_objects = [
...   Student('john', 'A', 15),
...   Student('jane', 'B', 12),
...   Student('dave', 'B', 10),
... ]
>>> sorted(student_objects, key=lambda student: student.age)  # sort by age
[('dave', 'B', 10), ('jane', 'B', 12), ('john', 'A', 15)]

以上所述是小编给大家介绍的python中sort()与sorted()的区别,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Python 相关文章推荐
python中from module import * 的一个坑
Jul 20 Python
Python连接数据库学习之DB-API详解
Feb 07 Python
python+django加载静态网页模板解析
Dec 12 Python
PyTorch搭建一维线性回归模型(二)
May 22 Python
PyQt5图形界面播放音乐的实例
Jun 17 Python
Python实现自定义读写分离代码实例
Nov 16 Python
Python 获取命令行参数内容及参数个数的实例
Dec 20 Python
python两个_多个字典合并相加的实例代码
Dec 26 Python
python判断变量是否为int、字符串、列表、元组、字典的方法详解
Feb 13 Python
python使用Thread的setDaemon启动后台线程教程
Apr 25 Python
python编写实现抽奖器
Sep 10 Python
Django项目如何正确配置日志(logging)
Apr 29 Python
Python实现拷贝/删除文件夹的方法详解
Aug 29 #Python
Python读写zip压缩文件的方法
Aug 29 #Python
使用python生成杨辉三角形的示例代码
Aug 29 #Python
Python实现查询某个目录下修改时间最新的文件示例
Aug 29 #Python
有关Python的22个编程技巧
Aug 29 #Python
Python实现多线程的两种方式分析
Aug 29 #Python
Python运维自动化之nginx配置文件对比操作示例
Aug 29 #Python
You might like
同台服务器使用缓存APC效率高于Memcached的演示代码
2010/02/16 PHP
PHP压缩html网页代码(清除空格,换行符,制表符,注释标记)
2012/04/02 PHP
PHP5.4中json_encode中文转码的变化小结
2013/01/30 PHP
探讨捕获php错误信息方法的详解
2013/06/09 PHP
PHP使用Memcache时模拟命名空间及缓存失效问题的解决
2016/02/27 PHP
用javascript getComputedStyle获取和设置style的原理
2008/10/10 Javascript
Javascript 验证上传图片大小[客户端]
2009/08/01 Javascript
一个简单的JavaScript数据缓存系统实现代码
2010/10/24 Javascript
微信WeixinJSBridge API使用实例
2015/05/25 Javascript
NodeJS实现阿里大鱼短信通知发送
2016/01/17 NodeJs
原生js实现查询天气小应用
2016/12/09 Javascript
jQuery实现的页面遮罩层功能示例【测试可用】
2017/10/14 jQuery
初学者AngularJS的环境搭建过程
2017/10/27 Javascript
vue自定义全局组件(自定义插件)的用法
2018/01/30 Javascript
Less 安装及基本用法
2018/05/05 Javascript
Node.js一行代码实现静态文件服务器的方法步骤
2019/05/07 Javascript
Webpack 4如何动态切割JS注入文件名详解
2019/07/09 Javascript
JS 图片压缩原理与实现方法详解
2020/04/29 Javascript
vuex 多模块时 模块内部的mutation和action的调用方式
2020/07/24 Javascript
Python编程入门之Hello World的三种实现方式
2015/11/13 Python
python+selenium开发环境搭建图文教程
2017/08/11 Python
Django中cookie的基本使用方法示例
2018/02/03 Python
python3.6+opencv3.4实现鼠标交互查看图片像素
2018/02/26 Python
Selenium控制浏览器常见操作示例
2018/08/13 Python
详解重置Django migration的常见方式
2019/02/15 Python
Python中的异常处理try/except/finally/raise用法分析
2019/02/28 Python
详解Python计算机视觉 图像扭曲(仿射扭曲)
2019/03/27 Python
python爬虫-模拟微博登录功能
2019/09/12 Python
Python requests设置代理的方法步骤
2020/02/23 Python
Windows环境下Python3.6.8 importError: DLLload failed:找不到指定的模块
2020/11/01 Python
维多利亚的秘密官方旗舰店:VICTORIA’S SECRET
2018/04/02 全球购物
英国领先的男装设计师服装独立零售商:Repertoire Fashion
2020/10/19 全球购物
周鸿祎:教你写创业计划书
2013/12/30 职场文书
幼儿园教师考核制度
2014/02/01 职场文书
微信早安问候语
2015/11/10 职场文书
小学生禁毒教育心得体会
2016/01/15 职场文书