开始一直以为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)
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)