如何在 Python 中过滤 JSON 数组

要在 Python 中过滤 JSON 数组:

  1. 使用 json.loads() 方法将 JSON 数组转换为 Python 列表。
  2. 使用列表理解来遍历列表。
  3. 检查列表中的每一项是否满足特定条件并返回结果。
import json

json_array = json.dumps(
    [
        {'name': 'Alice', 'salary': 100},
        {'name': 'Zadmei', 'salary': 50},
        {'name': 'Carl', 'salary': 75}
    ]
)

a_list = json.loads(json_array)

filtered_list = [
    dictionary for dictionary in a_list
    if dictionary['salary'] > 50
]

# 👇️ [{'name': 'Alice', 'salary': 100}, {'name': 'Carl', 'salary': 75}]
print(filtered_list)

json.dumps 方法将 Python 对象转换为 JSON 格式的字符串。

相反,json.loads 方法将 JSON 字符串解析为本机 Python 对象。

我们使用 json.loads() 方法将 JSON 数组转换为原生 Python 列表。

然后我们使用列表理解来迭代列表。

在每次迭代中,我们检查是否满足特定条件并返回结果。

代码示例检查每个字典是否有一个值大于 50 的 salary 键。

import json

json_array = json.dumps(
    [
        {'name': 'Alice', 'salary': 100},
        {'name': 'Zadmei', 'salary': 50},
        {'name': 'Carl', 'salary': 75}
    ]
)

a_list = json.loads(json_array)

filtered_list = [
    dictionary for dictionary in a_list
    if dictionary['salary'] > 50
]

# 👇️ [{'name': 'Alice', 'salary': 100}, {'name': 'Carl', 'salary': 75}]
print(filtered_list)

新列表只包含满足条件的词典。

我们可以使用这种方法来检查任何条件。

或者,我们可以使用 for 循环。


如何使用 for 循环过滤 JSON 数组

要在 Python 中过滤 JSON 数组:

  1. 使用 json.loads() 方法将 JSON 数组转换为 Python 列表。
  2. 使用 for 循环遍历列表。
  3. 检查每个列表项是否满足特定条件。
  4. 将匹配项附加到新列表。
import json

json_array = json.dumps(
    [
        {'name': 'Alice', 'salary': 100},
        {'name': 'Zadmei', 'salary': 50},
        {'name': 'Carl', 'salary': 75}
    ]
)

a_list = json.loads(json_array)

filtered_list = []

for dictionary in a_list:
    if dictionary['salary'] > 50:
        filtered_list.append(dictionary)

# 👇️ [{'name': 'Alice', 'salary': 100}, {'name': 'Carl', 'salary': 75}]
print(filtered_list)

我们使用 for 循环遍历列表。

在每次迭代中,我们检查当前字典是否有一个值大于 50 的 salary 键。

如果满足条件,我们使用 list.append() 方法将字典附加到新列表。

list.append() 方法将一个项目添加到列表的末尾。

新列表仅包含原始列表中满足条件的项目。

我们可以使用相同的方法来过滤存储在文件中的 JSON 数组。


在 Python 中过滤存储在文件中的 JSON 数组

要过滤存储在文件中的 JSON 数组:

  1. 以阅读模式打开 JSON 文件。
  2. 使用 JSON.load() 方法将文件反序列化为 Python 列表。
  3. 使用列表理解来过滤列表。
import json

file_name = 'example.json'

with open(file_name, 'r', encoding='utf-8') as f:
    a_list = json.load(f)

    # 👇️ [{'name': 'Alice', 'salary': 100}, {'name': 'Zadmei', 'salary': 50}, {'name': 'Carl', 'salary': 75}]
    print(a_list)

    filtered_list = [
        dictionary for dictionary in a_list
        if dictionary['salary'] > 50
    ]

    # 👇️ [{'name': 'Alice', 'salary': 100}, {'name': 'Carl', 'salary': 75}]
    print(filtered_list)

该代码示例假定我们有一个 example.json 文件存储在与 main.py 脚本相同的目录中。

example.json

[
  {"name": "Alice", "salary": 100},
  {"name": "Bobby", "salary": 50},
  {"name": "Carl", "salary": 75}
]

json.load 方法用于将文件反序列化为 Python 对象。

另一方面,json.loads 方法用于将 JSON 字符串反序列化为 Python 对象。

json.load() 方法需要一个包含实现 .read() 方法的 JSON 文档的文本文件或二进制文件。

一旦我们将 JSON 文件中的数据解析为本机 Python 列表,我们就可以使用列表理解或 for 循环来过滤列表。

我们还可以使用 filter() 函数来过滤 JSON 数组。


使用 filter() 函数过滤 JSON 数组

要在 Python 中过滤 JSON 数组:

  1. 使用 json.loads() 函数将 JSON 数组解析为 Python 列表。
  2. 将 lambda 函数和列表传递给 filter() 函数。
  3. lambda 函数应检查每个列表项是否满足条件。
import json

json_array = json.dumps(
    [
        {'name': 'Alice', 'salary': 100},
        {'name': 'Zadmei', 'salary': 50},
        {'name': 'Carl', 'salary': 75}
    ]
)

a_list = json.loads(json_array)

filtered_list = list(
    filter(
        lambda dictionary: dictionary['salary'] > 50,
        a_list
    )
)

# 👇️ [{'name': 'Alice', 'salary': 100}, {'name': 'Carl', 'salary': 75}]
print(filtered_list)

filter 函数接受一个函数和一个可迭代对象作为参数,并从可迭代对象的元素构造一个迭代器,函数返回一个真值。

我们传递给 filter() 的 lambda 函数被列表中的每个字典调用。

该函数检查字典是否满足特定条件并返回结果。

最后一步是使用 list() 类将过滤器对象转换为列表。