2

我不知道如何循环一个比 1 级更深的 JSON 对象。对象是:

{
  "data":[
    {
      "id":"251228454889939/insights/page_fan_adds_unique/day",
      "name":"page_fan_adds_unique",
      "period":"day",
      "values":[
        {
          "value":9,
          "end_time":"2012-05-29T07:00:00+0000"
        },
        {
          "value":5,
          "end_time":"2012-05-30T07:00:00+0000"
        }
      ],
      "title":"Daily New Likes",
      "description":"Daily The number of new people who have liked your Page (Unique Users)"
    },
    {
      "id":"251228454889939/insights/page_fan_adds/day",
      "name":"page_fan_adds",
      "period":"day",
      "values":[
        {
          "value":9,
          "end_time":"2012-05-29T07:00:00+0000"
        },
        {
          "value":5,
          "end_time":"2012-05-30T07:00:00+0000"
        }
      ],
      "title":"Daily New Likes",
      "description":"Daily The number of new people who have liked your Page (Total Count)"
    }
  ]
}

代码:

def parseJsonData(data):
    output_json = json.loads(data)
    for i in output_json:
        print i
        for k in output_json[i]:
            print k

为什么我不能像这样访问对象:output_json[data][id]?如果我尝试这个,我会得到一个错误:

字符串索引必须是整数

4

2 回答 2

5

由于您的“数据”键实际上是一个对象列表,因此您不能直接通过它们的“id”字段访问这些项目。您需要通过列表索引访问每个项目,例如:
output_json["data"][0]["id"]

现在,如果您想要做的是能够通过“id”字段作为键来索引“data”的成员,您可以重新格式化您的数据:

# make "data" a dict {id: item, }, instead of list [item1, item2, ...]
output_json['data'] = dict((item['id'], item) for item in json_data['data'])

print output_json['data']
# {'251228454889939/insights/page_fan_adds_unique/day': ...

print output_json['data']['251228454889939/insights/page_fan_adds_unique/day']
# {'description': 'Daily The number of new p ...

# ways to loop over "data"
for id_, item in output_json['data'].iteritems():
    print id_, item

for item in output_json['data'].itervalues():
    print item

否则,您要做的只是遍历“数据”,因为索引和对象之间没有真正的相关性:

for item in output_json["data"]:
    print item['id']

# 251228454889939/insights/page_fan_adds_unique/day
# 251228454889939/insights/page_fan_adds/day
于 2012-06-01T19:30:14.447 回答
2

您粘贴的不是有效的 JSON。在“数据”之后有一个不匹配的 [。

基于此,我猜可能数据不是您认为的那样。如果 output_json[data] 的值是一个列表,那么您将无法访问output_json[data][id]. 相反,您必须执行类似的操作output_json[data][0][id],其中 [0] 访问列表中的第一项。

于 2012-06-01T19:04:44.110 回答