我有一张单子,以后我想把它变成一本字典。问题是列表的列表非常不规则:对于一个键,1到4个列表中的数字属于该键。原始数据集存储在json中。 这是一个示例数据集:
data = [36146779,
[17628,35633, 2847385, 71393, 41814],[51068348,49722,3255134,66598],[103475099, 1337536, 1136863360,257],
22971125,
[230806,116805,118456,9031, 3573662],[719279707,299836,40722,35134,668],[1337536, 1136863360,257],
111125168,
[719279707,299836,40722,35138],[17628,35633, 2847385],
71280747,
[806,116805,11845],[17628,35633, 2847385]]
我能够完全平展列表列表,但我卡住了把这个平面列表变成一个字典与给定的键
ex_eco = ["36146779","22971125","111125168","71280747"]
(我确信也可以直接将第一个嵌套列表转换为字典,但我找不到解决方案,所以我尝试了这种方法)
def flatten(l):
out = []
for item in l:
if isinstance(item, (list, tuple)):
out.extend(flatten(item))
else:
out.append(item)
return out
flattened_eco = flatten(data)
print(flattened_eco[0:100])
我得到的是一个简单的列表:
[36146779, 17628, 35633, 2847385, 71393, 41814, 51068348, 49722, 3255134, 66598, 103475099, 1337536, 1136863360, 257, 22971125, 230806, 116805, 118456, 9031, 3573662, 719279707, 299836, 40722, 35134, 668, 1337536, 1136863360, 257, 111125168, 719279707, 299836, 40722, 35138, 17628, 35633, 2847385, 71280747, 806, 116805, 11845, 17628, 35633, 2847385]
我需要的是这样的东西:
[36146779,
[17628,35633, 2847385, 71393,41814,51068348,49722,3255134,66598,103475099,1337536, 1136863360,257],
22971125,
[230806,116805,118456,9031,573662,719279707,299836,40722,35134,668,1337536, 1136863360,257],
111125168,
[719279707,299836,40722,35138,17628,35633, 2847385],
71280747,
[806,116805,11845,17628,35633, 2847385]
]
示例
要进一步创建字典,只需将函数的最后一行更改为
dict
从您的输入来看,似乎不需要递归函数,只需使用迭代:
使用提供的数据输出:
例如
O/p:
相关问题 更多 >
编程相关推荐