1

我是 Python 新手(上周),已经达到了我的极限。花了三天时间,我大部分时间都在stackoverflow上,但我不知道如何走得更远!

Json多个嵌套数组。它可以包含三个(如下例 (json.txt) 所示)或 30 个。我需要遍历每个,然后深入到“局”,最后得到“小门”的值。这是我感到困惑的最后一步。任何人都可以建议吗?

你完全绝望

将要

import os, json,requests
print 'Starting'
url = 'https://dl.dropboxusercontent.com/u/3758695/json.txt'

# download the json string
json_string = requests.get(url)
print 'Downloaded json'

# get the content
the_data = json_string.json()
print 'the_data has length ', len(the_data)
for index in range(len(the_data)):
    print 'Now working on index ', index
    for wicket in the_data[index]:
            print 'wicket equals ',wicket
                    # OK - I can see Innings. Now, how do I get inside
                    # and obtain 'wickets'?
4

3 回答 3

4

首先,不要使用索引,而是直接在列表上循环;这样你就可以给他们起有意义的名字。顶层是一个条目列表,每个条目是一个带有'innings'键的字典,每个条目是一个字典innings列表,其中包括一个wickets键:

for entry in data:
    for inning in entry['innings']:
        print inning['wickets']

这打印:

>>> for entry in data:
...     for inning in entry['innings']:
...         print inning['wickets']
... 
10
9
0
0

这也使得在每个级别添加信息变得更加容易:

>>> for entry in data:
...     print entry['description']
...     for i, inning in enumerate(entry['innings']):
...         print 'Innings {}: {} wickets'.format(i + 1, inning['wickets'])
... 
Rest of Sri Lanka v Sri Lanka A at Pallekele, May 14, 2013
Innings 1: 10 wickets
Innings 2: 9 wickets
63rd match: Royal Challengers Bangalore v Kings XI Punjab at Bangalore, May 14, 2013
Innings 1: 0 wickets
Innings 2: 0 wickets
64th match: Chennai Super Kings v Delhi Daredevils at Chennai, May 14, 2013
于 2013-05-14T17:12:03.040 回答
0
import os, json,requests
print 'Starting'
url = 'https://dl.dropboxusercontent.com/u/3758695/json.txt'

# download the json string
json_string = requests.get(url)
print 'Downloaded json'

# get the content
the_data = json_string.json()
print 'the_data has length ', len(the_data)
for index in range(len(the_data)):
    print 'Now working on index ', index
    for d in the_data[index]['innings']:
        print d['wickets']
于 2013-05-14T17:17:21.890 回答
0

它看起来很丑,但你可以改进它,但这里列出了任意深度的 Dict 和 List 混合:

import os, json,requests
print 'Starting'
url = 'https://dl.dropboxusercontent.com/u/3758695/json.txt'

# download the json string
json_string = requests.get(url)
print 'Downloaded json'

def dig_down(partial_json_list, depth):
    if type(partial_json_list) is list:
        for i in range(len(partial_json_list)):
            print 'index', i, ' at depth', depth,' has', len(partial_json_list[i]) , 'elements'
            if len(partial_json_list[i]) > 1:
                dig_down(partial_json_list[i],depth+1)
    else:
        for k in partial_json_list:
            print 'item at depth', depth, 'equals', k#, ' & has', len(partial_json_list[k]) , 'elements'
            if type(partial_json_list) is list or type(partial_json_list) is dict:
                try:
                    if len(partial_json_list[k]) > 1:
                        dig_down(partial_json_list[k],depth+1)
                except:
                    pass
            else:
                print partial_json_list[k]

# get the content
the_data = json_string.json()
print 'the_data has length ', len(the_data)
dig_down(the_data,0)
于 2013-05-14T17:58:48.380 回答