python list排序的两种方法及实例讲解
对List进行排序,Python提供了两个方法方法1 用List的内建函数list sort进行排序list sort(func=None, key=None, reverse=False)Python实
对List进行排序,Python提供了两个方法
方法1.用List的内建函数list.sort进行排序
list.sort(func=None, key=None, reverse=False)
Python实例:
1
2
3
4
5
6
|
>>> list = [ 2 , 5 , 8 , 9 , 3 ] >>> list [ 2 , 5 , 8 , 9 , 3 ] >>> list .sort() >>> list [ 2 , 3 , 5 , 8 , 9 ] |
方法2.用序列类型函数sorted(list)进行排序(从2.4开始)
Python实例:
1
2
3
4
5
|
>>> list = [ 2 , 5 , 8 , 9 , 3 ] >>> list [ 2 , 5 , 8 , 9 , 3 ] >>> sorted ( list ) [ 2 , 3 , 5 , 8 , 9 ] |
两种方法的区别:
sorted(list)返回一个对象,可以用作表达式。原来的list不变,生成一个新的排好序的list对象。
list.sort() 不会返回对象,改变原有的list。
其他sort的实例:
实例1:正向排序
1
2
3
4
|
>>>L = [ 2 , 3 , 1 , 4 ] >>>L.sort() >>>L >>>[ 1 , 2 , 3 , 4 ] |
实例2:反向排序
1
2
3
4
|
>>>L = [ 2 , 3 , 1 , 4 ] >>>L.sort(reverse = True ) >>>L >>>[ 4 , 3 , 2 , 1 ] |
实例3:对第二个关键字排序
1
2
3
4
|
>>>L = [( 'b' , 6 ),( 'a' , 1 ),( 'c' , 3 ),( 'd' , 4 )] >>>L.sort( lambda x,y: cmp (x[ 1 ],y[ 1 ])) >>>L >>>[( 'a' , 1 ), ( 'c' , 3 ), ( 'd' , 4 ), ( 'b' , 6 )] |
实例4: 对第二个关键字排序
1
2
3
4
|
>>>L = [( 'b' , 6 ),( 'a' , 1 ),( 'c' , 3 ),( 'd' , 4 )] >>>L.sort(key = lambda x:x[ 1 ]) >>>L >>>[( 'a' , 1 ), ( 'c' , 3 ), ( 'd' , 4 ), ( 'b' , 6 )] |
实例5: 对第二个关键字排序
1
2
3
4
5
|
>>>L = [( 'b' , 2 ),( 'a' , 1 ),( 'c' , 3 ),( 'd' , 4 )] >>> import operator >>>L.sort(key = operator.itemgetter( 1 )) >>>L >>>[( 'a' , 1 ), ( 'b' , 2 ), ( 'c' , 3 ), ( 'd' , 4 )] |
实例6:(DSU方法:Decorate-Sort-Undercorate)
1
2
3
4
5
6
|
>>>L = [( 'b' , 2 ),( 'a' , 1 ),( 'c' , 3 ),( 'd' , 4 )] >>>A = [(x[ 1 ],i,x) for i,x in enumerate (L)] #i can confirm the stable sort >>>A.sort() >>>L = [s[ 2 ] for s in A] >>>L >>>[( 'a' , 1 ), ( 'b' , 2 ), ( 'c' , 3 ), ( 'd' , 4 )] |
以上给出了6中对List排序的方法,其中实例3.4.5.6能起到对以List item中的某一项
为比较关键字进行排序.
效率比较:
cmp < DSU < key
通过实验比较,方法3比方法6要慢,方法6比方法4要慢,方法4和方法5基本相当
多关键字比较排序:
实例7:
1
2
3
4
|
>>>L = [( 'd' , 2 ),( 'a' , 4 ),( 'b' , 3 ),( 'c' , 2 )] >>> L.sort(key = lambda x:x[ 1 ]) >>> L >>>[( 'd' , 2 ), ( 'c' , 2 ), ( 'b' , 3 ), ( 'a' , 4 )] |
我们看到,此时排序过的L是仅仅按照第二个关键字来排的,
如果我们想用第二个关键字排过序后再用第一个关键字进行排序呢?有两种方法
实例8:
1
2
3
4
|
>>> L = [( 'd' , 2 ),( 'a' , 4 ),( 'b' , 3 ),( 'c' , 2 )] >>> L.sort(key = lambda x:(x[ 1 ],x[ 0 ])) >>> L >>>[( 'c' , 2 ), ( 'd' , 2 ), ( 'b' , 3 ), ( 'a' , 4 )] |
实例9:
1
2
3
4
|
>>> L = [( 'd' , 2 ),( 'a' , 4 ),( 'b' , 3 ),( 'c' , 2 )] >>> L.sort(key = operator.itemgetter( 1 , 0 )) >>> L >>>[( 'c' , 2 ), ( 'd' , 2 ), ( 'b' , 3 ), ( 'a' , 4 )] |
为什么实例8能够工作呢?原因在于tuple是的比较从左到右比较的,比较完第一个,如果
相等,比较第二个
python list排序的两种方法及实例讲解的更多相关文章
- 转:python list排序的两种方法及实例讲解
对List进行排序,Python提供了两个方法 方法1.用List的内建函数list.sort进行排序 list.sort(func=None, key=None, reverse=False) Py ...
- 用Java集合中的Collections.sort方法对list排序的两种方法
用Collections.sort方法对list排序有两种方法第一种是list中的对象实现Comparable接口,如下: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 ...
- 用Python计算幂的两种方法,非递归和递归法
用Python计算幂的两种方法: #coding:utf-8 #计算幂的两种方法.py #1.常规方法利用函数 #不使用递归计算幂的方法 """ def power(x, ...
- 实现对多维数组按照某个键值排序的两种方法(array_multisort和array_sort)
实现对多维数组按照某个键值排序的两种解决方法(array_multisort和array_sort): 第一种:array_multisort()函数对多个数组或多维数组进行排序. //对数组$ ...
- Python修改文件的两种方法
目录: 一.以占用内存的方式修改文件 二.以占用硬盘的方式修改文件 引言 文件修改的方法从操作方式上大致可以分为两类,一种是以占用电脑内存的方式,将文件读取到内存中修改再存回硬盘:第二种方法是分别打开 ...
- python-快速排序,两种方法→易理解
快速排序(Quicksort)是对冒泡排序的一种改进. 快速排序由C. A. R. Hoare在1962年提出.它的基本思想是:通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另 ...
- python更新数据库脚本两种方法
最近项目的两次版本迭代中,根据业务需求的变化,需要对数据库进行更新,两次分别使用了不同的方式进行更新. 第一种:使用python的MySQLdb模块利用原生的sql语句进行更新 import MySQ ...
- 【Python】python更新数据库脚本两种方法
最近项目的两次版本迭代中,根据业务需求的变化,需要对数据库进行更新,两次分别使用了不同的方式进行更新. 第一种:使用python的MySQLdb模块利用原生的sql语句进行更新 1 import ...
- 使用Python生成源文件的两种方法
利用Python的字符串处理模块,开发者能够编写脚本用来生成那些格式同样的C.C++.JAVA源程序.头文件和測试文件,从而避免大量的反复工作. 本文概述两种利用Python string类生成jav ...
随机推荐
- String 方法
import java.lang.*; /** * 1.查找"asdfjvjadsffvaadfkfasaffdsasdffadsafafsafdadsfaafd" * 该字符串中 ...
- java_设计模式_单例模式_Singleton Pattern(2016-08-04)
概念: 单例模式确保某个类只有一个实例,而且自行实例化并向整个系统提供这个实例. 适用场景: 在计算机系统中,线程池.缓存.日志对象.对话框.打印机.显卡的驱动程序对象常被设计成单例.这些应用都或多或 ...
- APP被Rejected 的各种原因翻译(转)
原文:http://www.cnblogs.com/sell/archive/2013/02/16/2913341.html Terms and conditions(法律与条款) 1.1 As a ...
- Atom package安装失败的解决方案
cd ~/.atom/package git clone [package url] cd [package name] apm install [package name] if lack some ...
- ThinkPHP接入支付宝支付功能
最近做系统,需要实现在线支付功能,毫不犹豫,选择的是支付宝的接口支付功能.这里我用的是即时到帐的接口,具体实现的步骤如下: 一.下载支付宝接口包 下载地址:https://b.alipay.com/o ...
- opencv在VS2010命令行编译过程
最近这两天一直在研究命令行参数的编译,现代吗如下: #include <highgui.h> #include <math.h> #include <cv.h> I ...
- TatukGIS - GisDefs - CheckDir 函数
函数名称 CheckDir 所在单元 GisDefs 函数原型 function CheckDir(const _path: String): Boolean; 函数说明 如果 _path ...
- 自动文档摘要评价方法:Edmundson,ROUGE
自动文档摘要评价方法大致分为两类: (1)内部评价方法(Intrinsic Methods):提供参考摘要,以参考摘要为基准评价系统摘要的质量.系统摘要与参考摘要越吻合, 质量越高. (2)外部评价方 ...
- House Of Hello恶搞包为什么如此受热捧!
凤凰时尚 在大多数人的心中,奢侈品都是昂贵的,摆在精美的橱窗中,动辄上万的价格,高贵而冷艳,也让很多人望而却步.然而,最近在很多时尚年轻一族中却流传着这样一句话“昂贵不等于奢侈,奢侈是一种生活态 ...
- [BZOJ 1084] [SCOI2005] 最大子矩阵 【DP】
题目链接:BZOJ - 1084 题目分析 我看的是神犇BLADEVIL的题解. 1)对于 m = 1 的情况, 首先可能不取 Map[i][1],先 f[i][k] = f[i - 1][k]; ...