Python JSON解析重复记录

时间:2015-05-23 00:14:45

标签: python json

在我的JSON文件中,我有一系列同名的记录

"ability_upgrades":{
    "ability":5155,
    "time":1226
},
"ability_upgrades":{
    "ability":5155,
    "time":1426
},
"ability_upgrades":{
    "ability":5155,
    "time":1497
},
"ability_upgrades":{
    "ability":5157,
    "time":1543
},

如果我使用json.loads,它将仅保存最后一条记录 如果我想要一个ability_upgrades列表,我该怎么做?

1 个答案:

答案 0 :(得分:4)

The documentation表示object_pairs_hook中名为json.loads的参数可用于处理重复记录:

>>> json.loads(s, object_pairs_hook=(lambda x:  x))
[(u'ability_upgrades', [(u'ability', 5155), (u'time', 1226)]), (u'ability_upgrades', [(u'ability', 5155), (u'time', 1426)]), (u'ability_upgrades', [(u'ability', 5155), (u'time', 1497)]), (u'ability_upgrades', [(u'ability', 5157), (u'time', 1543)])]

如何定义该功能完全取决于您希望它是什么。在上面的示例中,由于该钩子将对象列表作为参数获取,因此身份函数只返回列表。

,例如,如果你定义:

def collectAbilityUpgrades(s):
    d = {}
    for k, v in s:
        if k not in d:
            d[k] = []
        d[k].append(v)
    return d

然后:

>>> json.loads(s, object_pairs_hook=collectAbilityUpgrades)
{u'ability_upgrades': [{u'ability': [5155], u'time': [1226]}, {u'ability': [5155], u'time': [1426]}, {u'ability': [5155], u'time': [1497]}, {u'ability': [5157], u'time': [1543]}]}

这可能与你想要的相似。