Python 字典(键值对)排序

Python 字典(键值对)排序,第1张

开始一直以为python没有现成的key-value存储方法,后来查了一下发现是有字典的,搞得自己还用类写结构体折腾了半天,但是相较起来二者还是各有各的好处吧,不过目前自己主要是想实现一个key-value的存储并排序,那肯定还是现成的字典最符合需求

字典的表示形式:

mp = {key1 : value1, key2 : value2 }

字典新增元素:(这里使用while读入的方式,一般不会手动一个一个添加元素,lis为自定义的结构体)

   class item(object):
       def __init__(self):
         self.name = ''
         self.info = []
         
    i = 0 
    while (i < length):
    #注意dict.has_key()已经在python 3.x中被弃用了,换成了__contains__(key)
        if not mp.__contains__(lis[i].name):
            mp[lis[i].name] = []
            mp[lis[i].name].append(lis[i].info)
        else:
            mp[lis[i].name].append(lis[i].info)
        i += 1

字典的排序:

# dict.items()以列表返回可遍历的(键, 值) 元组数组,在进行排序之前需要转换为元组数组
# key=lambda x: x[1]表示按照第几个元素进行排序,比如x: x[1]表示按照第二个元素
mp_sort = sorted(mp_sorted.items(), key=lambda x: x[1], reverse=True)
# dict()如果仍然需要字典格式需要调用dict()函数进行对应的转化
mp_sort = dict(mp_sort)

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/716052.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-04-25
下一篇 2022-04-25

发表评论

登录后才能评论

评论列表(0条)

保存