您现在的位置是:亿华云 > 人工智能
Python字典不是不可以排序,是你方法没用对!
亿华云2025-10-09 01:32:47【人工智能】5人已围观
简介字典是Python语言中的一种数据结构,每一个字典元素是由一对key-value组成的。而字典的key和value分别以集合(Set)形似组织,以便快速查询。集合的存储形似通常是树的结构,所以搜索非常
字典是字典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_keys和dict_values是Python的两个内部类,他们都采用了树的用对结构对数据进行组织。现在的字典问题是,集合是可排无序的(因为是以树状结构存储的),但由于某些要求,序方我们期望得到有序的源码下载法没键值,这就引出了下面的用对几个问题:
Q1:集合可以排序吗?
Q2:排序后,可以获取成对的key-value吗?
Q3:除了按键值排序,可以按值排序吗?
为了回答这几个问题,请继续看下面的内容。
1. 集合可以排序吗?
这个问题的答案是:No。既然称为集合,由于数据存储形式的原因,肯定是无序的,但我们可以做一个折中的处理。既然集合不能排序,那么可以将集合中的数据排序后,放到一个可以排序的数据结构(例如,列表)里,这样可以在一定程度上解决我们的问题。看下面的代码:
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了,代码如下:
x = { x:20,a:12,b:5} keys = sorted(x.keys()) for key in keys: print(f"{ key}:{ x[key]}")执行这段代码,b2b信息网会输出如下的内容:
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,可以使用下面的代码:
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转换为有序字典,代码如下:
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对象中。
本文转载自微信公众号「极客起源」,可以通过以下二维码关注。转载本文请联系极客起源公众号。
很赞哦!(1661)
相关文章
- 尽量不要在域名中出现特殊字符,这样的域名很容易导致访问者输入错误,同时给人留下不专业的印象,降低网站的可信度,并流失大量潜在客户。
- HBase+Elasticsearch,百亿级数据中心架构设计实践
- 使用服务器产生的热量来发电,让数据中心整体运营成本降低50%
- 面试官:Tomcat是如何处理Http请求的?
- 3、不明先知,根据相关征兆预测可能发生的事件,以便提前做好准备,赶紧注册相关域名。;不差钱域名;buchaqian抢先注册,就是这种敏感类型。预言是最敏感的状态。其次,你应该有眼力。所谓眼力,就是善于从社会上时不时出现的各种热点事件中获取与事件相关的域名资源。眼力的前提是对域名领域的熟悉和丰富的知识。
- 数据中心和人工智能如何支持远程工作场所?
- 为什么服务端程序都需要先 Listen 一下?
- Linux 系统服务器异常流量分析
- 为了避免将来给我们的个人站长带来的麻烦,在选择域名后缀时,我们的站长最好省略不稳定的后缀域名,比如n,因为我们不知道策略什么时候会改变,更不用说我们将来是否还能控制这个域名了。因此,如果站长不是企业,或者有选择的话,如果不能选择域名的cn类,最好不要选择它。
- 小白系列之Flask服务器部署