摘要:排序是个古老的话题,不过对于字典的排序,常常会让 小白手足无措。好像没有找到可以排序字典的函数呢!到底是按key排序,还是按value排序呢?字典到底可不可以按value排序呢?排完序后,还可以通过key检索吗?当然,还会抛出很多问题,而本文将完美地给出了这些问题的答案!

字典是Python语言中的一种数据结构,每一个字典元素是由一对key-value组成的。而字典的key和value分别以集合(Set)形似组织,以便快速查询。集合的存储形似通常是树的结构,所以搜索非常快。我们可以单独通过字典的keys方法和values方法获取键集合和值集合的可迭代对象,代码如下:

x = {'x':20,'a':12,'b':5}
print(x.keys())
print(x.values())

执行这段代码,会输出如下的内容:

dict_keys(['x', 'a', 'b'])
dict_values([20, 12, 5])

PS:dict_keysdict_values是Python的两个内部类,他们都采用了树的结构对数据进行组织。

现在的问题是,集合是无序的(因为是以树状结构存储的),但由于某些要求,我们期望得到有序的键值,这就引出了下面的几个问题:
Q1:集合可以排序吗?
Q2:排序后,可以获取成对的key-value吗?
Q3:除了按键值排序,可以按值排序吗?
为了回答这几个问题,请继续看下面的内容。

1. 集合可以排序吗?

这个问题的答案是:No。既然称为集合,由于数据存储形式的原因,肯定是无序的,但我们可以做一个折中的处理。既然集合不能排序,那么可以将集合中的数据排序后,放到一个可以排序的数据结构(例如,列表)里,这样可以在一定程度上解决我们的问题。
看下面的代码:

'''
遇到问题没人解答?小编创建了一个Python学习交流QQ群:778463939
寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!
'''
x = {'x':20,'a':12,'b':5}
keys = sorted(x.keys())
values = sorted(x.values())
print(type(keys))
print(type(values))
print(keys)
print(values)

在这段代码中,使用了sorted函数,该函数可以用于对序列进行排序,并将排序结果放到一个列表中,最后返回这个列表,所以执行这段代码,会输出如下的内容:

<class 'list'>
<class 'list'>
['a', 'b', 'x']
[5, 12, 20]

现在我们的第一个问题解决了,使用sorted函数,将集合按升序排列,并以列表形式体现。如果想降序排列,那么需要将reverse参数设置为True,代码如下:

keys = sorted(x.keys(), reverse=True)
values = sorted(x.values(), reverse=True)

2. 排序后,可以获取成对的key-value吗?

现在来解决第2个问题。本文讨论的是字典,所以即使对key和value排序,也不是我们期望的,我们期望的是得到字典中的key-value对,而且是已经排序好的key-value对。
这个问题也非常好解决,既然已经得到了排好序的key,那么就利用key从字典中获得对应的value,这样就可以组成一对key-value了,代码如下:

'''
遇到问题没人解答?小编创建了一个Python学习交流QQ群:778463939
寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!
'''
x = {'x':20,'a':12,'b':5}
keys = sorted(x.keys())
for key in keys:print(f"{key}:{x[key]}")

执行这段代码,会输出如下的内容:

x:20
b:5
a:12

很明显,输出的key-value对是按key升序排列的。

3. 除了按键值排序,可以按值排序吗?

那值排序是没问题的,但排好序的值是没什么用的。因为字典并不能通过value反向获取key。所以通过前面的方法只能获取排好序的值。所以需要为sorted函数的key参数,该参数用于指定使用key还是value进行排序。如果使用的是Python 3.7或以上版本。可以为key参数值指定lambda表达式,代码如下:

y1 = {k: v for k, v in sorted(x.items(), key=lambda item: item[1])}
print(y1)
# 按值降序排列
y2 = {k: v for k, v in sorted(x.items(), key=lambda item: item[1], reverse=True)}
print(y2)

这段代码使用了for-in表达式生成了字典,其中x是待排序的字典。items获取了key-value对。而lambda表达式的item就是当前的key-value对。item[0]表示key,item[1]表示value,所以使用item[1],就表示按value排序,而使用item[0],就是按key排序。

执行这段代码,会输出如下的结果:

{'b': 5, 'a': 12, 'x': 20}
{'x': 20, 'a': 12, 'b': 5}

如果不想使用for-in表达式,也可以使用dict函数,代码如下:

print(dict(sorted(x.items(), key=lambda item: item[1])))

如果不想使用lambda表达式,或需要更复杂的排序规则,可以自定义排序规则函数,代码如下:

def dict_val(x):return x[1]sorted_x = sorted(x.items(), key=dict_val)

如果读者用的是3.6或以下版本的Python,可以使用下面的代码:

'''
遇到问题没人解答?小编创建了一个Python学习交流QQ群:778463939
寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!
'''
import operator
# 按value
sorted_x = sorted(x.items(), key=operator.itemgetter(1))
print(type(sorted_x))  # list
print(sorted_x)  # 所以用列表替代import operator
# 按key
sorted_x = sorted(x.items(), key=operator.itemgetter(0))
print(sorted_x)

在这段代码中,会返回排好序的列表,列表元素是元组形式,第1个值是key,第2个值是value。当然,你可以将这些数据重新插入新的字典中。执行这段代码,会输出如下内容:

[('b', 5), ('a', 12), ('x', 20)]
[('a', 12), ('b', 5), ('x', 20)]

如果仍然想通过key搜索字典中的value,可以利用OrderedDict对象将sorted_x转换为有序字典,代码如下:

'''
遇到问题没人解答?小编创建了一个Python学习交流QQ群:778463939
寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!
'''
import collections
sorted_dict = collections.OrderedDict(sorted_x)
print(type(sorted_dict))
print(sorted_dict)
print(sorted_dict.get('b'))

执行这段代码,会输出如下内容:

<class 'collections.OrderedDict'>
OrderedDict([('a', 12), ('b', 5), ('x', 20)])
5

总结:本文的核心就是sorted函数,通过这个函数,既可以对key和value集合进行排序,也可以对key-value对进行排序,如果是后者,需要通过key指定到底是用key,还是用value排序,sorted函数返回的是排好序的列表,如果要得到排好序的字典,或者使用for-in表达式处理,或者使用dict函数转换。当然,如果只是想通过key搜索value,也可以将数据放到OrderedDict对象中。

Python字典的排序方法,你用对了吗相关推荐

  1. python字典怎么排序_如何对python的字典进行排序

    我们知道Python的内置dictionary数据类型是无序的,通过key来获取对应的value.可是有时我们需要对dictionary中 的item进行排序输出,可能根据key,也可能根据value ...

  2. Python 字典(Dictionary) get()方法

    Python 字典(Dictionary) get()方法 描述 Python 字典(Dictionary) get() 函数返回指定键的值,如果值不在字典中返回默认值. 语法 get()方法语法: ...

  3. [转载] Python字典的setdefault()方法

    参考链接: Python字典setdefault() Python字典的setdefault()方法 (2012-06-22 02:18:05)转载▼ setdefault(key[, default ...

  4. Python字典及其使用方法

    Python字典及其使用方法 字典的定义 Python中的字典属于散列类型,其数据内容是以键值对的形式存在.即{ k e y : v a l u e } {key:value}{key:value}的 ...

  5. Python 字典(dict) clear() 方法

    字典(dict)是 Python 提供的一种常用的数据结构,它用于存放具有映射关系的数据.Python字典可存储任意类型对象,如字符串.数字.元组等,优点是取值方便,速度快.本文主要介绍Python ...

  6. python字典排序方法_Python字典的排序方法一则

    今天需要对Python的字典进行排序,以获得有效的时间序列,采用了如下方法: 首先生成一个示例字典: >>> range_a = random.sample(range(0, 10) ...

  7. python字典value排序_python字典按照value排序方法

    python中,我们可以对列表.字符串.元祖中的元素进行排序,那对于字典中的元素可以排序吗?其实对于字典本身我们无法进行排序,但是我们可以对字典按值排序.本文介绍python中对字典按照value进行 ...

  8. Python:字典列表字符串方法测试

    测试的一些Python中的关于字典.列表.字符串的使用方法,放在这里备查. 整个测试代码和说明如下: # -*- coding: utf-8 -*- """Python: ...

  9. python字典操作的方法_python 字典操作方法详解

    python 字典操作方法详解 一.总结 一句话总结: 字典就是键值对映射 ,像js和php中的键值对数组:{'name':'jamnes','age':'32'} 1.python字典的增删改查? ...

最新文章

  1. c++ 浮点数转换成字符串_Python如何处理数据?如何把数据转换成我们想要的?三种处理方法...
  2. 用户太多太杂,搞不懂怎么办?“分门别类”将拯救你
  3. [NOIP2006] 数列
  4. php基础教程 第五步 逻辑控制
  5. 阿里云oss上传图片
  6. [机器学习-数学] 矩阵求导(分母布局与分子布局),以及常用的矩阵求导公式
  7. 国庆档电影《我和我的祖国》3天票房破10亿
  8. OpenCV系列(一)之图像平滑
  9. Warning: Binary output can mess up your terminal. Use “--output -“ to tell
  10. JMeter之压力测试
  11. Java 案例大全(详细)一
  12. Paraview源码解析8: vtkPVGlyphFilter类
  13. 程序人生之三:从新手到项目管理,五年程序人生路
  14. 老路MBA商学课|第004课:边际成本|飞机起飞前的座位,只卖一块钱?
  15. laravel 微信支付easywechat
  16. 探索MapReduce过程及分组详解
  17. C++标准库分析总结(一)——<标准库简介>
  18. 13. Linux权限管理命令
  19. 12.23网络嗅探实验记录
  20. js钢琴(含钢琴按键音效包)

热门文章

  1. 英国电信宣布2030年前碳排放削减87%
  2. 触发器无法启动分布式事务。
  3. 分布学在flash当中的应用体现
  4. ad 卡尔曼_对Kalman(卡尔曼)滤波器的理解
  5. mapreduce编程规范_大数据之MapReduce详解
  6. 【学习笔记】SAP CO模块概念信息(上)
  7. 【学习笔记】产品成本计划(Product Cost Planning)01
  8. sap Status状态栏设计
  9. ABAP ALV 颜色设置(行,列,单元格)
  10. 分行与支行有什么区别