按多个字段筛选数据
创始人
2024-10-14 04:30:48
0

下面是一个示例代码,演示了如何按多个字段筛选数据:

from itertools import filterfalse

# 定义一个数据列表
data = [
    {'name': 'Alice', 'age': 25, 'city': 'New York'},
    {'name': 'Bob', 'age': 30, 'city': 'San Francisco'},
    {'name': 'Charlie', 'age': 35, 'city': 'New York'},
    {'name': 'David', 'age': 40, 'city': 'San Francisco'},
    {'name': 'Eve', 'age': 45, 'city': 'New York'}
]

# 定义筛选条件
filters = [
    {'field': 'age', 'operator': '>', 'value': 30},
    {'field': 'city', 'operator': '==', 'value': 'San Francisco'}
]

# 定义一个函数来检查是否满足筛选条件
def check_filter(record, filter):
    field = filter['field']
    operator = filter['operator']
    value = filter['value']
    
    if operator == '>':
        return record[field] > value
    elif operator == '<':
        return record[field] < value
    elif operator == '==':
        return record[field] == value
    elif operator == '!=':
        return record[field] != value
    else:
        return False

# 使用filter函数来筛选数据
filtered_data = filter(lambda x: all(check_filter(x, f) for f in filters), data)

# 使用filterfalse函数来筛选数据
filtered_data = filterfalse(lambda x: any(not check_filter(x, f) for f in filters), data)

# 打印筛选结果
for record in filtered_data:
    print(record)

这个示例代码中,首先定义了一个数据列表data,其中包含了一些字典对象。然后定义了一个筛选条件列表filters,每个筛选条件都是一个字典对象,包括字段名、操作符和值。

接下来定义了一个check_filter函数,用来检查每个记录是否满足筛选条件。然后使用filter函数来筛选满足所有筛选条件的数据。也可以使用filterfalse函数来筛选不满足任何一个筛选条件的数据。

最后,遍历筛选结果,打印每个满足条件的记录。

相关内容

热门资讯

微信小程序黑科技免费!微乐自建... 微信小程序黑科技免费!微乐自建房脚本免费入口(开挂)app-一贯有挂是有挂1、辅助器安装包、辅助器2...
微信小程序黑科技免费!微信小程... 微信小程序黑科技免费!微信小程序微乐房间有技巧吗(开挂)教程-本来曝光存在有挂1、每一步都需要思考,...
微乐小程序存在有挂!微乐小程序... 微乐小程序存在有挂!微乐小程序辅助教程(开挂)方法-原来分享是有挂;1、每一步都需要思考,不同水平的...
微乐小程序真的有挂!微乐家乡小... 微乐小程序真的有挂!微乐家乡小程序修改器(开挂)教程-一贯分享存在有挂1、点击下载安装,脚本分类一目...
微信小程序黑科技免费!小程序微... 微信小程序黑科技免费!小程序微乐贵阳捉鸡麻将挂(开挂)脚本-切实辅助是有挂1、上手简单,内置详细流程...
微乐小程序透视挂!微乐自建房脚... 微乐小程序透视挂!微乐自建房脚本最新版本更新内容(开挂)神器-确实推荐真的有挂1、有没有辅助教程、有...
微信小程序黑科技免费!微乐小程... 微信小程序黑科技免费!微乐小程序自建房辅助ios(开挂)软件-都是有挂真的是有挂1、下载好正确养号方...
微乐小程序透视辅助!微乐小程序... 微乐小程序透视辅助!微乐小程序自建房透视(开挂)技巧-确实解迷真的有挂1、完成辅助器v3.3的残局,...
微乐小程序透视辅助!微信微乐游... 微乐小程序透视辅助!微信微乐游戏破解器(开挂)器-都是辅助存在有挂1、操作简单,无需手机版透视脚本,...
微乐小程序透视挂!微乐家乡ap... 微乐小程序透视挂!微乐家乡app辅助器(开挂)挂-总是专业真的有挂1、每一步都需要思考,不同水平的挑...