Python 函数读取 JSON 文件并检索正确的值



我正在读取一个 JSON 文件以使用我的 extract_json 函数检索一些值,并通过time_minutes_coords = extract_json("boxes", "time_minutes", "coord")调用它,这为我提供了通往坐标值的正确路径。

  def extract_json(one,two,three):
    with open('document.json') as data_file:
        data = json.load(data_file)
        return data[one][two][three]

但它仅适用于 3 个参数。如果我想将此函数用于传递的任意数量的参数怎么办?我想要这样的东西:

  def extract_json(*args): 
    with open('document.json') as data_file: 
        data = json.load(data_file) 
        return data[args] 

但是所有的参数都以这种方式显示:

(args1, args2, args3, args4)

data(args1, args2, args3, args4)什么也没返回。我怎么能有这样的东西:

data[args1][args2][args3]

[args4]

移动到 JSON 文件中的正确值?

你可以通过 jsonpath-rw 模块使用 JSONPath 解决它。工作样品:

from jsonpath_rw import parse
obj = {
    "glossary": {
        "title": "example glossary",
        "GlossDiv": {
            "title": "S",
            "GlossList": {
                "GlossEntry": {
                    "ID": "SGML",
                    "SortAs": "SGML",
                    "GlossTerm": "Standard Generalized Markup Language",
                    "Acronym": "SGML",
                    "Abbrev": "ISO 8879:1986",
                    "GlossDef": {
                        "para": "A meta-markup language, used to create markup languages such as DocBook.",
                        "GlossSeeAlso": ["GML", "XML"]
                    },
                    "GlossSee": "markup"
                }
            }
        }
    }
}
keys = ["glossary", "GlossDiv", "GlossList", "GlossEntry", "GlossDef", "para"]
jsonpath_expr = parse(".".join(keys))
print(jsonpath_expr.find(obj)[0].value)

指纹:

A meta-markup language, used to create markup languages such as DocBook.

在这里,键以列表的形式出现(在您的情况下是args)。然后,将键与dot连接起来,以构造指向所需节点的路径。

相关内容

  • 没有找到相关文章

最新更新