网站建设资讯

NEWS

网站建设资讯

python3排序函数,python3排序算法

python字母顺序排序

1. (按字母顺序排列)——sort()函数

创新互联专注于石拐网站建设服务及定制,我们拥有丰富的企业做网站经验。 热诚为您提供石拐营销型网站建设,石拐网站制作、石拐网页设计、石拐网站官网定制、微信小程序服务,打造石拐网络公司原创品牌,更为您提供石拐网站排名全网营销落地服务。

例:

cars =['bmw','audi','toyota','subaru']

cars.sort()

print(cars)

输出得到

['audi', 'bmw', 'subaru', 'toyota']

请点击输入图片描述

请点击输入图片描述

2.按字母反序排列——reverse函数

cars =['bmw','audi','toyota','subaru']

cars.sort(reverse=True)# reverse“adj. 反面的;颠倒的;n. 倒转,反向”

print(cars)

输出得到

['toyota', 'subaru', 'bmw', 'audi']

请点击输入图片描述

请点击输入图片描述

3.对列表进行临时排序——sorted()函数

cars =['bmw','audi','toyota','subaru']

print("Here is the original list:")

print(cars)

print("\nHere is the sorted list:")

print(sorted(cars))

print("Here is the original list again:")

print(cars)

输出得到

Here is the original list:

['bmw', 'audi', 'toyota', 'subaru']

Here is the sorted list:

['audi', 'bmw', 'subaru', 'toyota']

Here is the original list again:

['bmw', 'audi', 'toyota', 'subaru']

请点击输入图片描述

请点击输入图片描述

4. 倒着打印列表——reverse()函数

cars =['bmw','audi','toyota','subaru']

print(cars)

cars.reverse()

print(cars)

输出得到

['bmw', 'audi', 'toyota', 'subaru']

['subaru', 'toyota', 'audi', 'bmw']

请点击输入图片描述

请点击输入图片描述

python3用sorted排序

如果a = [ [1,'3'], [1,'2'],[2,'5'],[2,'4'] ]

有两种解决方式:

方法一:

将字符串转换为int

sorted(list, key=lambda x:(x[0],-int(x[1])))

方法二:

取字符串的第一个字母进行比较

s = sorted(a, key=lambda x:(x[0],x[1][0]))

这个方法当字符串为一串单词时,也有效

python3.0中sorted函数怎么用

【Python】 sorted函数

我们需要对List、Dict进行排序,Python提供了两个方法

对给定的List L进行排序,

方法1.用List的成员函数sort进行排序,在本地进行排序,不返回副本

方法2.用built-in函数sorted进行排序(从2.4开始),返回副本,原始输入不变

--------------------------------sorted---------------------------------------

help(sorted)

Help on built-in function sorted in module __builtin__:

sorted(...)

sorted(iterable, cmp=None, key=None, reverse=False) -- new sorted list

---------------------------------sort----------------------------------------

help(list.sort)

Help on method_descriptor:

sort(...)

L.sort(cmp=None, key=None, reverse=False) -- stable sort *IN PLACE*;

cmp(x, y) - -1, 0, 1

-----------------------------------------------------------------------------

iterable:是可迭代类型;

cmp:用于比较的函数,比较什么由key决定;

key:用列表元素的某个属性或函数进行作为关键字,有默认值,迭代集合中的一项;

reverse:排序规则. reverse = True 降序 或者 reverse = False 升序,有默认值。

返回值:是一个经过排序的可迭代类型,与iterable一样。

参数说明:

(1) cmp参数

cmp接受一个函数,拿整形举例,形式为:

def f(a,b):

return a-b

如果排序的元素是其他类型的,如果a逻辑小于b,函数返回负数;a逻辑等于b,函数返回0;a逻辑大于b,函数返回正数就行了

(2) key参数

key也是接受一个函数,不同的是,这个函数只接受一个元素,形式如下

def f(a):

return len(a)

key接受的函数返回值,表示此元素的权值,sort将按照权值大小进行排序

(3) reverse参数

接受False 或者True 表示是否逆序

例子:

(1)按照元素长度排序

L = [{1:5,3:4},{1:3,6:3},{1:1,2:4,5:6},{1:9}]

def f(x):

return len(x)

sort(key=f)

print L

输出:

[{1: 9}, {1: 5, 3: 4}, {1: 3, 6: 3}, {1: 1, 2: 4, 5: 6}]

(2)按照每个字典元素里面key为1的元素的值排序

L = [{1:5,3:4},{1:3,6:3},{1:1,2:4,5:6},{1:9}]

def f2(a,b):

return a[1]-b[1]

L.sort(cmp=f2)

print L

. 对由tuple组成的List排序

Python代码

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

用key函数排序:返回由tuple组成的list

Python代码

sorted(students, key=lambda student : student[2]) # sort by age

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

用cmp函数排序

Python代码

sorted(students, cmp=lambda x,y : cmp(x[2], y[2])) # sort by age

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

用 operator 函数来加快速度,

Python代码

from operator import itemgetter, attrgetter

sorted(students, key=itemgetter(2))

用 operator 函数进行多级排序

Python代码

sorted(students, key=itemgetter(1,2)) # sort by grade then by age

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

2. 对由字典排序 ,返回由tuple组成的List,不再是字典。

Python代码

d = {'data1':3, 'data2':1, 'data3':2, 'data4':4}

sorted(d.iteritems(), key=itemgetter(1), reverse=True)

[('data4', 4), ('data1', 3), ('data3', 2), ('data2', 1)]


文章标题:python3排序函数,python3排序算法
文章源于:http://njwzjz.com/article/dscsdeg.html