简体   繁体   English

如何从列表列表中创建字典并对其进行排序?

[英]How to create a dictionary from a list of lists and sort it?

Please tell me how to create a dictionary from the existing list:请告诉我如何从现有列表中创建字典:

my_list = [[['id_1', 'A', 10], ['id_1', 'C', 3], ['id_1', 'B', 2]],
          [['id_2', 'E', 4], ['id_2', 'A', 3], ['id_2', 'D', 1]],
          [['id_3', 'B', 3], ['id_3', 'C', 1]],
          [['id_4', 'E', 10], ['id_4', 'A', 5], ['id_4', 'B', 4], ['id_4', 'F', 2]]]

I need to get a dictionary like this:我需要这样的字典:

dictionary = {'A': [('id_1', 10 ), ('id_4', 5), ('id_2', 3)],
              'B': [('id_4', 4), ('id_3', 3), ('id_1', 2)],
              'C': [('id_1', 3), ('id_3', 1)],
              'D': [('id_2', 1)],
              'E': [('id_4', 10), ('id_2', 4)],
              'F': [('id_4', 2)]
              }

Thanks for the help!谢谢您的帮助!

You can just use nested loops..你可以只使用嵌套循环..

my_dict = {}
for i in my_list:
    for j in i:
        try: 
            my_dict[j[1]] += [(j[0], j[-1])]
        except KeyError: 
            my_dict[j[1]] = [(j[0], j[-1])]
my_dict = dict(sorted(my_dict.items()))
my_dict

----------------------------------------------------
{'A': [('id_1', 10), ('id_2', 3), ('id_4', 5)],
 'B': [('id_1', 2), ('id_3', 3), ('id_4', 4)],
 'C': [('id_1', 3), ('id_3', 1)],
 'D': [('id_2', 1)],
 'E': [('id_2', 4), ('id_4', 10)],
 'F': [('id_4', 2)]}
----------------------------------------------------

You can try this:你可以试试这个:

my_list = [[['id_1', 'A', 10], ['id_1', 'C', 3], ['id_1', 'B', 2]],
          [['id_2', 'E', 4], ['id_2', 'A', 3], ['id_2', 'D', 1]],
          [['id_3', 'B', 3], ['id_3', 'C', 1]],
          [['id_4', 'E', 10], ['id_4', 'A', 5], ['id_4', 'B', 4], ['id_4', 'F', 2]]]

flattened = [item for sublist in my_list for item in sublist]

my_dict = {}

for _id, ltr, num in flattened:
    if ltr in my_dict: # changed from my_dict.keys()
        my_dict[ltr].append((_id, num))
    else:
        my_dict[ltr] = [(_id, num)]

sorted_dict = dict(sorted(my_dict.items()))

print(sorted_dict)

If you want to know, this is what flattened , my_dict and sorted_dict look like:如果你想知道,这就是flattenedmy_dictsorted_dict的样子:

flattened = [
    ['id_1', 'A', 10], ['id_1', 'C', 3], ['id_1', 'B', 2],
    ['id_2', 'E', 4], ['id_2', 'A', 3], ['id_2', 'D', 1],
    ['id_3', 'B', 3], ['id_3', 'C', 1], ['id_4', 'E', 10],
    ['id_4', 'A', 5], ['id_4', 'B', 4], ['id_4', 'F', 2]
]

my_dict = {
    'A': [('id_1', 10), ('id_2', 3), ('id_4', 5)],
    'C': [('id_1', 3), ('id_3', 1)],
    'B': [('id_1', 2), ('id_3', 3), ('id_4', 4)],
    'E': [('id_2', 4), ('id_4', 10)],
    'D': [('id_2', 1)],
    'F': [('id_4', 2)]
}

sorted_dict = {
    'A': [('id_1', 10 ), ('id_4', 5), ('id_2', 3)],
    'B': [('id_4', 4), ('id_3', 3), ('id_1', 2)],
    'C': [('id_1', 3), ('id_3', 1)],
    'D': [('id_2', 1)],
    'E': [('id_4', 10), ('id_2', 4)],
    'F': [('id_4', 2)]
}

Start with a defaultdict and append values from my_list then sort.defaultdict开始并从my_list ,然后排序。

from collections import defaultdict

my_list = [[['id_1', 'A', 10], ['id_1', 'C', 3], ['id_1', 'B', 2]],
          [['id_2', 'E', 4], ['id_2', 'A', 3], ['id_2', 'D', 1]],
          [['id_3', 'B', 3], ['id_3', 'C', 1]],
          [['id_4', 'E', 10],['id_4', 'A', 5],['id_4', 'B', 4], ['id_4', 'F', 2]]]

d = defaultdict(list) 
[d[i[1]].append((i[0],i[2])) for j in my_list for i in j]
dictionary = dict(sorted(d.items()))

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM