【转载+修改】Python3中的sort方法使用基础

Python3中的sort()方法使用基础

一、基本形式:

1.主要函数sort()和sorted()

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

iterable.sort(cmp[, key[, reverse]])

 参数解释:

 (1)iterable指定要排序的list或者iterable,不用多说;

 (2)cmp为函数,指定排序时进行比较的函数,可以指定一个函数或者lambda函数,如:

       students为类对象的list,每个成员有三个域,用sorted进行比较时可以自己定cmp函数,例如这里要通过比较第三个数据成员来排序,代码可以这样写:

students = [('john', 'A', 15), ('jane', 'B', 12), ('dave', 'B', 10)]
sorted(students, key=lambda student : student[2])

(3)key为函数,指定取待排序元素的哪一项进行排序,函数用上面的例子来说明,代码如下:

sorted(students, key=lambda student : student[2])

       key指定的lambda函数功能是去元素student的第三个域(即:student[2]),因此sorted排序时,会以students所有元素的第三个域来进行排序。

二、普通用法:

1.原址排序

1)列表有自己的sort方法,其对列表进行原址排序。

     既然是原址排序,那显然元组不可能使用这种方法(元组是不可修改的)。

x = [4, 6, 2, 1, 7, 9]
x.sort()
print (x) #不可以直接输出printed(x.sort())

2.副本排序

1)y = x[:]分片方法

x =[4, 6, 2, 1, 7, 9]
y = x[ : ]
y.sort()
print (y) #[1, 2, 4, 6, 7, 9]
print (x) #[4, 6, 2, 1, 7, 9]

注意:y = x[:] 通过分片操作将列表x的元素全部拷贝给y。

          如果简单的把x赋值给y,即y = x。y和x仍然指向同一个列表,并没有产生新的list副本。

2)y=sorted(x)函数

sorted函数可以返回一个有序的list副本,如下:

x =[4, 6, 2, 1, 7, 9]
y = sorted(x)
print (y) #[1, 2, 4, 6, 7, 9]
print (x) #[4, 6, 2, 1, 7, 9] 
print (sorted('Python')) #['P', 'h', 'n', 'o', 't', 'y']
三、高级用法:

1.sorted函数中的key和reverse

1)reverse实现降序排序,需要提供一个布尔值,默认为False(升序排列)。

2)key在使用时必须提供一个排序过程总调用的函数:

alist = [('2', '3', '10'), ('1', '2', '3'), ('5', '6', '7'), ('2', '5', '10'), ('2', '4', '10')]
# 多级排序,先按照第3个元素排序,然后按照第2个元素排序:
print (sorted(alist, key = lambda x:(int(x[2]), int(x[1])), reverse = False))
#-------------------------------------------------------------------------------------------
##[('1', '2', '3'), ('5', '6', '7'), ('2', '3', '10'), ('2', '4', '10'), ('2', '5', '10')]
2.operator模块

operator模块提供的itemgetter函数可以定义抓取函数

import operator
print('\noperator模块下itemegetter函数测试')

a = [10,2,3]
b=operator.itemgetter(2,1)      
c=b(a)
print('a中第2和第1个元素分别为',c)
print(c[0]>c[1])

a = ['10','2','3']
b=operator.itemgetter(2,1)      
c=list(map(int,b(a)))
print('a中第2和第1个元素分别为',c)
print(c[0]>c[1])
print(int(c[0])>int(c[1]))
要注意,operator.itemgetter方法实际上定义了一个变换函数b(),因此需要通过将该函数b()作用到对象a上才具有实际意义。  

itemgetter在sort中的用法:

#print('\noperator模块下itemegetter函数排序测试')
from operator import itemgetter
alist = [('2', '3', '10'), ('1', '2', '3'), ('5', '6', '7'), ('2', '5', '10'), ('2', '4', '10')]
b=itemgetter(2,1) 
print ('现列表',alist)
# 多级排序,先按照第3个元素排序,然后按照第2个元素降序排列:
print ('现列表',sorted(alist, key = b, reverse = False))
print ('现列表',sorted(alist, key = lambda x:b(x), reverse = False))
print ('现列表',sorted(alist, key = lambda x:list(map(int,b(x))), reverse = False))

猜你喜欢

转载自blog.csdn.net/qq_40628847/article/details/80211835
今日推荐