3

背景:

我在 JSON 中有以下示例数据结构:

{'sensor' : [
    {'assertions_enabled': 'ucr+',
     'deassertions_enabled': 'ucr+',
     'entity_id': '7.0',
     'lower_critical': 'na',
     'lower_non_critical': 'na',
     'lower_non_recoverable': 'na',
     'reading_type': 'analog',
     'sensor_id': 'SR5680 TEMP (0x5d)',
     'sensor_reading': {'confidence_interval': '0.500',
                    'units': 'degrees C',
                    'value': '42'},
     'sensor_type': 'Temperature',
     'status': 'ok',
     'upper_critical': '59.000',
     'upper_non_critical': 'na',
     'upper_non_recoverable': 'na'}
]}

传感器列表实际上将包含许多包含传感器信息的字典。

问题:

我正在尝试使用 jsonpath 查询列表,以向我返回具有sensor_type=='Temperature'但我被'False'返回的传感器字典的子集(不匹配)。这是我的 jsonpath 表达式:

results = jsonpath.jsonpath(ipmi_node, "$.sensor[?(@.['sensor_type']=='Temperature')]")

当我删除过滤器表达式并仅使用时"$.sensor.*",我会得到所有传感器的列表,所以我确定问题出在过滤器表达式中。

我扫描了多个站点/帖子以获取示例,但似乎找不到任何特定于 Python 的内容(Javascript 和 PHP 似乎更突出)。有人可以提供一些指导吗?

4

2 回答 2

5

以下表达式可以满足您的需要(注意属性是如何指定的):

jsonpath.jsonpath(impi_node, "$.sensor[?(@.sensor_type=='Temperature')]")
于 2012-09-09T22:29:44.647 回答
4

我正在使用似乎处于活动状态的jsonpath-ng(截至 23.11.20),并且我提供了基于 Pedro 的 jsonpath 表达式的解决方案:

data = {
    'sensor' : [
        {'sensor_type': 'Temperature', 'id': '1'},
        {'sensor_type': 'Humidity'   , 'id': '2'},
        {'sensor_type': 'Temperature', 'id': '3'},
        {'sensor_type': 'Density'    , 'id': '4'}
    ]} 

from jsonpath_ng.ext import parser
for match in parser.parse("$.sensor[?(@.sensor_type=='Temperature')]").find(data):
    print(match.value)

输出:

{'sensor_type': 'Temperature', 'id': '1'}
{'sensor_type': 'Temperature', 'id': '3'}

注意:除了项目主页上提供的基本文档外,我还在tests中找到了其他信息。

于 2020-11-23T14:26:27.350 回答