词典列表到相关词典列表

时间:2019-07-05 15:18:48

标签: python list dictionary

我有这个列表:

list = [ { 1: [3], 2: [6] }, { 3: [4,5], 6: [8] }, { 4: [7], 5: [7] } ]

它代表了我拥有的所有对象的对象ID之间的整体相关性。

我要从此列表中提取的内容:

l1 = [ { 1: [3] }, { 3: [4,5] }, { 4: [7], 5: [7] } ]

l2 = [ { 2: [6] }, { 6: [8] } ]

请允许我解释一下!

为清楚起见,请在下面找到图片:

enter image description here

因此,如您所见,每个对象都由其ID表示。要形成“列表”,我从左侧外围对象的ID开始,此类ID将是第一个字典(“列表”的关键字)的键,这些键的值是连接在列表上的对象的ID。正确(我们将值放在列表中)。这些值将成为第二个字典的键(如果您从上一个字典重复了值,则不要重复这些键,只需对它一次即可),并重复这些步骤直到找到最后一个ID。

这些对象根据其ID之间的关系形成图案。在这个问题上,我将得到它们正在形成的图案数量。在我提供链接的图片中,它们正在形成两种模式。

模式:是以某种方式相互关联的ID的对象组

1 个答案:

答案 0 :(得分:0)

对我有用:

my_dict = [ { 1: [3], 2: [6] }, { 3: [4,5], 6: [8] }, { 4: [7], 5: [7] } ]
new_dict = []

# read
def read(n, p, dictionary):
  a = list(dictionary[n])[p]
  if len(new_dict)<=p:
    new_dict.append([])
  new_dict[p].append({a : dictionary[n][a]})
  bucle(dictionary[n][a], n+1, p, dictionary)
def bucle(key, n, p, dictionary):
  try:
    for keys in key:
      new_dict[p].append({keys: dictionary[n][keys]})
      bucle(dictionary[n][keys], n+1, p, dictionary)
  except:
    pass
read(0, 0, my_dict)
read(0, 1, my_dict)
print(new_dict)

结果:

new_dict = [[{1: [3]}, {3: [4, 5]}, {4: [7]}, {5: [7]}], [{2: [6]}, {6: [8]}]]
new_dict[0] = [{1: [3]}, {3: [4, 5]}, {4: [7]}, {5: [7]}]
new_dict[1] = [{2: [6]}, {6: [8]}]