python中的排序

python中排序有两个函数第一个是sort(),第二个是sorted(),sort函数对序列进行永久性的改变,sorted函数在排序后会生成一个新的序列,原序列不变。

lst=[1,3,2]
lst,sort()
print lst

# 输出结果如下
# [1,2,3]
lst=[1,3,2]
print sorted(lst)
pritn lst

# 输出结果如下
# [1,2,3]
# [1,3,2]

python中的sorted()函数:

sorted()最简单的用法:sorted(list),这种方法直接将传入的list进行排序,返回升序排序的顺序。

sorted(list,reverse=True),这种方法将传入的list排序,返回降序序列。

sorted进阶用法:在使用sorted对一个list进行排序时,传入一个key值来实现自定义的排序。

sorted([1,8,5,-7],key=abs)

# 返回[1,5,7,8]

这里key会依次作用于list中的每一个元素上,实际上不会改变list中元素的值,根据key函数返回的结果进行排序。

sorted(['abc','Abc','Cba','bAc'],key=str.lower())

# 结果返回['abc','Abc','bAc','Cba']

sorted更高级的用法:sorted可以结合lambda进行排序,通过lambda可以实现条件更复杂的排序:

实现对嵌套list或者元组list排序:

sorted([['guo','A','25'],['shao','a','24'],['zhang','b','26'],['wang','c','33']],key=lambda x:x[2])

# 输出结果为
# [['shao', 'a', '24'], ['guo', 'A', '25'], ['zhang', 'b', '26'], ['wang', 'c', '33']]

实现对dict排序,dict代码逻辑同上。

 

你可能感兴趣的:(python中的排序)