python 集合排序 sorted 函数

Python使用sorted函数来排序:

 

l = [2,1,3,5,7,3]
print sorted(l)

执行结果:[1, 2, 3, 3, 5, 7]

 

 按列表每个元素,逗号前面的那个字符排序:

l=['c,3','a,5','d:4','b,2','a,3']
print sorted(l,key=lambda x:x.split(',')[0])

执行结果:['a,5', 'a,3', 'b,2', 'c,3', 'd:4']

 

也可以加上第二排序关键字:

l=['c,3','a,5','d,4','b,2','a,3']
print sorted(l,key=lambda x:(x.split(',')[0],x.split(',')[1]))

 执行结果:['a,3', 'a,5', 'b,2', 'c,3', 'd,4']

 

 按逗号后面的元素从大到小排列:

l=['c,3','a,5','d,4','b,2','a,3']
print sorted(l,cmp=lambda x,y:cmp(int(y.split(',')[1]),int(x.split(',')[1])))

 执行结果:['a,5', 'd,4', 'c,3', 'a,3', 'b,2']

 

 

字典排序也与其类似。

按key排序:

d={'b':2,'a':1,'d':4,'c':3}
print sorted(d.items(),key=lambda x:x[0])

 执行结果:[('a', 1), ('b', 2), ('c', 3), ('d', 4)]

 

按value排序:

d={'b':2,'a':1,'d':4,'c':3}
print sorted(d.items(),key=lambda x:x[1])

 执行结果:[('a', 1), ('b', 2), ('c', 3), ('d', 4)]

 

按value反序:

d={'b':2,'a':1,'d':4,'c':3}  
print sorted(d.items(),cmp=lambda x,y : cmp(int(y[1]),int(x[1])))

 

注意,sorted返回的是一个序列

 

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Python中的字典(dict)不支持排序,因为字典是无序的键值对集合。不过,我们可以利用sorted函数对字典的键(key)进行排序,并返回一个排序后的列表。具体操作如下: 1. 首先,我们需要一个字典作为输入。假设我们有一个字典d = {'b': 2, 'a': 1, 'c': 3}。 2. 使用sorted函数对字典的键进行排序,并将结果保存到一个新的列表中。列表的元素是按照键的排序顺序依次排列的。代码示例为sorted_keys = sorted(d.keys())。 3. 最后我们可以通过迭代sorted_keys列表,访问字典中的值。例如,可以使用for循环遍历sorted_keys,并打印每个键和对应的值。代码示例为:for key in sorted_keys: print(key, d[key])。 总结:通过sorted函数可以对字典的键进行排序,并返回一个排序后的键列表。然后,可以通过对排序后的键列表进行迭代,访问字典中的键和值。 ### 回答2: Python的`dict`类型是无序的键值对集合,`sorted()`函数可以对`dict`进行排序并返回一个有序的字典。 首先,我们需要明确字典本身是无序的,只是在Python 3.7及其之后的版本中,字典会以插入顺序来保持键值对的顺序。如果要按照键或值对字典进行排序,可以使用`sorted()`函数。 `sorted()`函数可以接受一个可迭代对象,并返回一个新的已排序的列表。如果我们想对字典按照键排序,可以使用`sorted()`函数的`key`参数来指定排序的准则。 下面是一个示例,展示了如何使用`sorted()`函数对字典按照键进行排序并返回有序的字典: ```python student_scores = {'Alice': 85, 'Bob': 75, 'Charlie': 90, 'David': 80} sorted_scores = sorted(student_scores.items(), key=lambda x: x[0]) sorted_dict = dict(sorted_scores) print(sorted_dict) ``` 输出结果为: ``` {'Alice': 85, 'Bob': 75, 'Charlie': 90, 'David': 80} ``` 上述代码中,我们将`student_scores`字典的键值对转换为元组并使用`sorted()`函数进行排序,`key`参数使用`lambda`函数指定了按照键进行排序的准则。最后,我们将排序后的元组转换回字典,并将结果打印出来。 需要注意的是,由于字典是无序的,即使使用`sorted()`函数对字典排序后获得了有序的字典,在其他版本或执行时,顺序可能会被改变。因此,在实际应用中,如果需要按照键或值对字典进行排序并保持顺序,建议使用`collections`模块中的`OrderedDict`类型。 ### 回答3: Python中的字典(dict)是一种无序的数据类型,其中的键-值对是没有固定顺序的。然而,我们可以使用内置函数sorted()来对字典进行排序,返回一个排序后的列表。下面是一个示例: ```python # 定义一个字典 my_dict = {'b': 2, 'c': 1, 'a': 3} # 使用sorted函数对字典进行排序 sorted_dict = sorted(my_dict.items()) # 打印排序后的结果 print(sorted_dict) ``` 上述代码中,我们先定义了一个字典my_dict,其中包含了三个键-值对。然后,我们使用sorted()函数对字典的items()方法返回的键值对进行排序。最后,将排序后的结果赋值给sorted_dict变量,并打印输出。 运行以上代码,将会输出以下结果: ``` [('a', 3), ('b', 2), ('c', 1)] ``` 这里,我们得到了一个排序后的列表,其中的元素是按照键的字母顺序排列的。在这个排序后的列表中,每个元素都是一个包含键和值的元组。 需要注意的是,sorted()函数返回的是一个列表,而不是一个字典。因为字典本身是无序的,所以无法直接返回一个有序的字典。如果你需要使用有序的字典结构,可以考虑使用collections模块中的OrderedDict类。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值