Python中使用sorted函数对dict进行排序

Python中的字典排序

参考:菜鸟教程

目的:对Python中dict这种类,使用 sorted 函数进行排序的总结,做一个备忘。

错误的排序方式

如果直接将dict丢进sorted:

key_value={}
key_value[2] = 56
key_value[1] = 2
key_value[5] = 12
key_value[4] = 24
key_value[6] = 18
key_value[3] = 323
key_value = sorted(key_value)
print(key_value)

得到结果如下:

[1, 2, 3, 4, 5, 6]

顺序是排好了,但是结果变成了key的列表

2 按照key或者value进行排序

2.1 按照key排序

key_value={}
key_value[2] = 56
key_value[1] = 2
key_value[5] = 12
key_value[4] = 24
key_value[6] = 18
key_value[3] = 323
key_value = dict(sorted(key_value.items(),key=lambda x:x[0],reverse=False))
print(key_value)

得到结果如下:

{1: 2, 2: 56, 3: 323, 4: 24, 5: 12, 6: 18}

将比第1节,有以下几处改变:

1、对sorted的返回值进行转换,因为sorted返回的是list数据类型

2、排序的对象是dict.items(),而不是dict本身

3、排序方式给定了lambda函数,可以自由规定排序方式(默认也是按照key排序)

3、reverse参数,设置是否反转(默认是false,从小到大)

2.2 按照value排序

key_value={}
key_value[2] = 56
key_value[1] = 2
key_value[5] = 12
key_value[4] = 24
key_value[6] = 18
key_value[3] = 323
key_value = dict(sorted(key_value.items(),key=lambda x:x[1],reverse=False))
print(key_value)

得到结果:

{1: 2, 5: 12, 6: 18, 4: 24, 2: 56, 3: 323}

3 自定义排序方式

举例按照key*value的值进行排序

key_value={}
key_value[0] = 0
key_value[-1] = -1
key_value[2] = 2
key_value[-3] = -3
key_value[4] = 4
key_value[-5] = -5
key_value = dict(sorted(key_value.items(),key=lambda x:(x[0]*x[1]),reverse=False))
print(key_value)

得到结果如下:

{0: 0, -1: -1, 2: 2, -3: -3, 4: 4, -5: -5}

自定义排序的方式,取决于对lambda 函数的定义。

仅仅作为个人学习记录,后续可能会补充。

 

 

 

 

 

  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值