Python字典不是不可以排序,是你技巧没用对!

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


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

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


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

PS:dict_keys和dict_values是Python的两个内部类,他们都采用了树的结构对数据进行组织。现在的问题是,集合是无序的(因为是以树状结构存储的),但由于某些要求,我们期望得到有序的键值,这就引出了下面的几个问题:

Q1:集合可以排序吗?

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

Q3:除了按键值排序,可以按值排序吗?

为了回答这几个问题,请继续看下面的内容。

1. 集合可以排序吗?

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


  1. x = {'x':20,'a':12,'b':5} 
  2. keys = sorted(x.keys()) 
  3. values = sorted(x.values()) 
  4. print(type(keys)) 
  5. print(type(values)) 
  6. print(keys) 
  7. print(values

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


  1. <class 'list'
  2. <class 'list'
  3. ['a''b''x'
  4. [5, 12, 20] 

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


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

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

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


  1. x = {'x':20,'a':12,'b':5} 
  2. keys = sorted(x.keys()) 
  3. for key in keys: 
  4.     print(f"{key}:{x[key]}"
【声明】:芜湖站长网内容转载自互联网,其相关言论仅代表作者个人观点绝非权威,不代表本站立场。如您发现内容存在版权问题,请提交相关链接至邮箱:bqsm@foxmail.com,我们将及时予以处理。

相关文章