获取嵌套字典中所有键的列表

Gat*_*ium 2 python dictionary nested

我想获取包含列表和字典的嵌套字典中所有键的列表。

我目前有这段代码,但似乎缺少向列表添加一些键,并且还重复添加了一些键。

keys_list = []
def get_keys(d_or_l, keys_list):
    if isinstance(d_or_l, dict):
        for k, v in iter(sorted(d_or_l.iteritems())):
            if isinstance(v, list):
                get_keys(v, keys_list)
            elif isinstance(v, dict):
                get_keys(v, keys_list)
            else:
                keys_list.append(k)
    elif isinstance(d_or_l, list):
        for i in d_or_l:
            if isinstance(i, list):
                get_keys(i, keys_list)
            elif isinstance(i, dict):
                get_keys(i, keys_list)
    else:
        print "** Skipping item of type: {}".format(type(d_or_l))
    return keys_list
Run Code Online (Sandbox Code Playgroud)

这仅需要一个空列表并用键填充它。d_or_l 是一个变量,并采用原始字典进行比较。

pm0*_*007 6

这应该可以完成这项工作:

def get_keys(dl, keys_list):
    if isinstance(dl, dict):
        keys_list += dl.keys()
        map(lambda x: get_keys(x, keys_list), dl.values())
    elif isinstance(dl, list):
        map(lambda x: get_keys(x, keys_list), dl)
Run Code Online (Sandbox Code Playgroud)

为了避免重复,您可以使用 set,例如:

keys_list = list( set( keys_list ) )
Run Code Online (Sandbox Code Playgroud)

测试用例示例:

keys_list = []
d = {1: 2, 3: 4, 5: [{7: {9: 1}}]}
get_keys(d, keys_list)
print keys_list
>>>> [1, 3, 5, 7, 9]
Run Code Online (Sandbox Code Playgroud)


Mac*_*ckM 5

按照目前的情况,您的代码会忽略导致listdict值的键。删除else第一个for循环中的块,无论值是什么,您都想添加键。

keys_list = []
def get_keys(d_or_l, keys_list):
    if isinstance(d_or_l, dict):
        for k, v in iter(sorted(d_or_l.iteritems())):
            if isinstance(v, list):
                get_keys(v, keys_list)
            elif isinstance(v, dict):
                get_keys(v, keys_list)
            keys_list.append(k)   #  Altered line
    elif isinstance(d_or_l, list):
        for i in d_or_l:
            if isinstance(i, list):
                get_keys(i, keys_list)
            elif isinstance(i, dict):
                get_keys(i, keys_list)
    else:
        print "** Skipping item of type: {}".format(type(d_or_l))
    return keys_list
Run Code Online (Sandbox Code Playgroud)

get_keys({1: 2, 3: 4, 5: [{7: {9: 1}}]}, keys_list)回报[1, 3, 9, 7, 5]

为了避免重复,您可以使用set数据类型而不是list.