百科狗-知识改变命运!
--

Python的字典排序

百变鹏仔1年前 (2023-11-21)阅读数 28#技术干货
文章标签字典

字典是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))

Python的字典排序

print(type(values))

print(keys)

print(values)

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

['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())

forkeyinkeys:

print(f"{key}:{x[key]}")

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

x:20

b:5

a:12

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

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

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

y1={k:vfork,vinsorted(x.items(),key=lambdaitem:item[1])}

print(y1)

#按值降序排列

y2={k:vfork,vinsorted(x.items(),key=lambdaitem: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=lambdaitem:item[1])))如果不想使用lambda表达式,或需要更复杂的排序规则,可以自定义排序规则函数,代码如下:

defdict_val(x):

returnx[1]

sorted_x=sorted(x.items(),key=dict_val)

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

importoperator

#按value

sorted_x=sorted(x.items(),key=operator.itemgetter(1))

print(type(sorted_x))#list

print(sorted_x)#所以用列表替代

importoperator

#按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转换为有序字典,代码如下:

importcollections

sorted_dict=collections.OrderedDict(sorted_x)

print(type(sorted_dict))

print(sorted_dict)

print(sorted_dict.get('b'))

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

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

5

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

以上内容为大家介绍了Python的字典排序,希望对大家有所帮助,如果想要了解更多Python相关知识,请关注IT培训机构:开发教育。http://www.baikegou.com/

鹏仔微信 15129739599 鹏仔QQ344225443 鹏仔前端 pjxi.com 共享博客 sharedbk.com

免责声明:我们致力于保护作者版权,注重分享,当前被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理!邮箱:344225443@qq.com)

图片声明:本站部分配图来自网络。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!

内容声明:本文中引用的各种信息及资料(包括但不限于文字、数据、图表及超链接等)均来源于该信息及资料的相关主体(包括但不限于公司、媒体、协会等机构)的官方网站或公开发表的信息。部分内容参考包括:(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供参考使用,不准确地方联系删除处理!本站为非盈利性质站点,本着为中国教育事业出一份力,发布内容不收取任何费用也不接任何广告!)