python - 如何获取嵌套字典列表中所有键的路径

标签 python dictionary key

我想获取列表中嵌套字典的所有键的路径。例如,如果我的字典如下所示

{
"persons": [{
    "id": "f4d322fa8f552",
    "address": {
        "building": "710",
        "coord": "[123, 465]",
        "street": "Avenue Road",
        "zipcode": "12345"
    },
    "cuisine": "Chinese",
    "grades": [{
        "date": "2013-03-03T00:00:00.000Z",
        "grade": "B",
        "score": {
          "x": 3,
          "y": 2
        }
    }, {
        "date": "2012-11-23T00:00:00.000Z",
        "grade": "C",
        "score": {
          "x": 1,
          "y": 22
        }
    }],
    "name": "Shash"
}]
}

我想得到这样的路径 path = [['persons'], ['persons','id'],['persons','address'],['persons','address','building']...] 直到最后一个键。

我试图遍历整个字典来追加路径变量。试图从 Print complete key path for all the values of a python nested dictionary 中获得一些灵感但我无法获得列表中的路径。

还有其他可能的方法吗?

最佳答案

您可以递归地描述数据结构,这是使用队列 q 与递归的一种方法。但很难判断这是否是您要查找的内容,因为它显示了列表索引,但可以很容易地排除它们:

def get_paths(d):
    q = [(d, [])]
    while q:
        n, p = q.pop(0)
        yield p
        if isinstance(n, dict):
            for k, v in n.items():
                q.append((v, p+[k]))
        elif isinstance(n, list):
            for i, v in enumerate(n):
                q.append((v, p+[i]))   # Change to q.append((v, p)) to remove index

In []:
list(get_paths(d))

Out[]:
[[],
 ['persons'],
 ['persons', 0],
 ['persons', 0, 'id'],
 ['persons', 0, 'address'],
 ['persons', 0, 'cuisine'],
 ['persons', 0, 'grades'],
 ['persons', 0, 'name'],
 ['persons', 0, 'address', 'building'],
 ['persons', 0, 'address', 'coord'],
 ['persons', 0, 'address', 'street'],
 ['persons', 0, 'address', 'zipcode'],
 ['persons', 0, 'grades', 0],
 ['persons', 0, 'grades', 1],
 ['persons', 0, 'grades', 0, 'date'],
 ['persons', 0, 'grades', 0, 'grade'],
 ['persons', 0, 'grades', 0, 'score'],
 ['persons', 0, 'grades', 1, 'date'],
 ['persons', 0, 'grades', 1, 'grade'],
 ['persons', 0, 'grades', 1, 'score'],
 ['persons', 0, 'grades', 0, 'score', 'x'],
 ['persons', 0, 'grades', 0, 'score', 'y'],
 ['persons', 0, 'grades', 1, 'score', 'x'],
 ['persons', 0, 'grades', 1, 'score', 'y'],

关于python - 如何获取嵌套字典列表中所有键的路径,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51373165/

相关文章:

python: langton's ant pygame 第一步问题

python - 使用 setuptools 可执行访问 yaml 配置文件

c# - 从字符串中读取字符并计算每个字符

python - 如何在 Python 中对字典中的值进行排序?

python - 阅读 excel 框架时跳过特定的一组列 - pandas

python - 根据另一列中的值更新特定列中的值

java - MapDB集合大小问题

python - 使用字典键-多值对对列进行分类

key - 使用Common Lisp CLOS对象作为哈希表中的键?

mysql - MySQL中的 "ADD KEY"和 "ADD INDEX"有什么区别?