json - 如何使用 Python jsonpath_ng 过滤器和其他扩展功能?

标签 json jsonpath

我正在尝试使用 Python 从 JSON 中提取有用信息的不同方法。我尝试了 jsonpath_rw_ext 和 jsonpath_ng。现在我可以使用 jsonpath_rw_ext 但 jsonpath_ng 不起作用。我不想放弃 jsonpath_ng 因为我可能没有以正确的方式使用它。检查以下代码:

import jsonpath_rw_ext
from jsonpath_ng.ext import parse
import json
from pprint import pprint


json_str = '''{
    "students": [
        {"name": "Peter", "gender": "Male", "age": 20},
        {"name": "Mary", "gender": "Female", "age": 30},
        {"name": "Susan", "gender": "Female", "age": 40}
    ],
    "teachers": [
        {"name": "William", "gender": "Male", "age": 30},
        {"name": "John", "gender": "Male", "age": 40},
        {"name": "Lucy", "gender": "Female", "age": 50}
    ]
}'''

json_obj = json.loads(json_str)
print 'jsonpath_rw_ext:'
female_students = jsonpath_rw_ext.match('$.students[?gender=="Female"]', json_obj)
pprint(female_students)
print 'jsonpath_ng:'
female_students = parse('$.students[?gender=="Female"]').find(json_obj)
pprint(female_students)

jsonpath_rw_ext 部分输出如下结果,正常:
jsonpath_rw_ext:
[{u'age': 30, u'gender': u'Female', u'name': u'Mary'},
 {u'age': 40, u'gender': u'Female', u'name': u'Susan'}]

但是 jsonpath_ng 部分输出了以下结果,我无法理解。 jsonpath_ng 返回以下结果有什么具体原因吗?我怎样才能以简单的方式获得类似的结果?

jsonpath_ng 返回的结果:
[
    DatumInContext(
        value={
            u'gender': u'Female', u'age': 30, u'name': u'Mary'
        }, 
        path=<jsonpath_ng.jsonpath.Index object at 0x000000000315AA90>, 
        context=DatumInContext(
            value=[
                {u'gender': u'Male', u'age': 20, u'name': u'Peter'}, 
                {u'gender': u'Female', u'age': 30, u'name': u'Mary'}, 
                {u'gender': u'Female', u'age': 40, u'name': u'Susan'}
            ], 
            path=Fields('students'), 
        context=DatumInContext(
            value={
                u'students': [
                    {u'gender': u'Male', u'age': 20, u'name': u'Peter'}, 
                    {u'gender': u'Female', u'age': 30, u'name': u'Mary'}, 
                    {u'gender': u'Female', u'age': 40, u'name': u'Susan'}
                ], 
                u'teachers': [
                    {u'gender': u'Male', u'age': 30, u'name': u'William'}, 
                    {u'gender': u'Male', u'age': 40, u'name': u'John'}, 
                    {u'gender': u'Female', u'age': 50, u'name': u'Lucy'}
                ]
            }, 
            path=Root(), 
            context=None
        )
        )
    ),
    DatumInContext(
        value={u'gender': u'Female', u'age': 40, u'name': u'Susan'}, 
        path=<jsonpath_ng.jsonpath.Index object at 0x000000000315ABA8>, 
        context=DatumInContext(
            value=[
                {u'gender': u'Male', u'age': 20, u'name': u'Peter'}, 
                {u'gender': u'Female', u'age': 30, u'name': u'Mary'}, 
                {u'gender': u'Female', u'age': 40, u'name': u'Susan'}
            ], 
            path=Fields('students'), 
            context=DatumInContext(
                value={
                    u'students': [
                        {u'gender': u'Male', u'age': 20, u'name': u'Peter'}, 
                        {u'gender': u'Female', u'age': 30, u'name': u'Mary'}, 
                        {u'gender': u'Female', u'age': 40, u'name': u'Susan'}
                    ], 
                    u'teachers': [
                        {u'gender': u'Male', u'age': 30, u'name': u'William'}, 
                        {u'gender': u'Male', u'age': 40, u'name': u'John'}, 
                        {u'gender': u'Female', u'age': 50, u'name': u'Lucy'}
                    ]
                }, 
                path=Root(), 
                context=None
            )
        )
    )
 ]

最佳答案

find() 方法返回 DatumInContext 对象的列表。所以你可以使用 List 解析。
为了从 DatumInContext 获取值,您可以使用其属性值,该值将返回与您在响应中获得的值相同的值

jsonpath_rw_ext.match('$.students[?gender=="Female"]', json_obj)

所以,而不是使用
pprint(female_students)

直接,您可以使用女学生通过解析列表项及其值
pprint([match.value for match in female_students])

关于json - 如何使用 Python jsonpath_ng 过滤器和其他扩展功能?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50287011/

相关文章:

json - 将值从 "&"转换为 JSON 时,Powershell 无法进行转换

json - 高级 JSON 查询语言

json - 使用 REST Assured,我如何检查一个字段是否存在于 json 对象类型的响应数组中?

javascript - 使用 JsonPath 和 karate.eval 在 Karate 中进行数组排序和匹配

json - node.js - 与 TCP 服务器通信(数据 == JSON)

javascript - 将 MVC3 模型作为 JSON 传递给 Javascript block

java - Jsonpath 总是返回空列表

javascript - JSONPATH 有什么优点?

java - 在不同服务器上运行的两个 Java Web 应用程序之间传输数据的最佳方式

python mailchimp api 2.0 json响应错误