NSPredicate-谓词使用总结

2024-01-31 10:48

本文主要是介绍NSPredicate-谓词使用总结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

简介

NSPredicate类主要用来指定过滤器的条件,该对象可以准确的描述所需条件,对每个对象通过谓词进行筛选,判断是否与条件相匹配。谓词是指在计算机中表示计算真假值的函数。原理和用法都类似于SQL查询中的where,作用相当于数据库的过滤取。主要用于从集合中分拣出符合条件的对象或者数据模型,也可以用于字符串的正则匹配.  
一般的, NSPredicate的筛选过滤的条件可以是, 逻辑运算符号(> , < , =),范围运算符(IN,BETWEEN),字符的包含/匹配/模糊搜索(BEGINSWITH,ENDSWITH,CONTAINS,LIKE), 正则表达式(MATCHES)等.

NSPredicate用法

1.谓词过滤筛选的过程

1.创建NSPredicate 
NSPredicate *predicate = [NSPredicate predicateWithFormat:@"过滤条件"];  
2.判断指定的对象是否满足NSPredicate创建的过滤条件  
[predicate evaluateWithObject:model];  
3.array通过创建的predicate进行过滤,并返回符合条件的数据  
NSArray *resultArr = [array filteredArrayUsingPredicate:predicate]; 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

这些方法既适用于字符串这样的简单对象的过滤, 又适用于数据模型的过滤.

举例: 
对简单的字符串数组进行包含过滤

    NSArray *array=[@"abc",@"adbzc",@"adboc",@"skenabc",@"aksalkjjbc2c",@"111abc",@"a22bc4",@"abc4444",@"asdfad",@"alkmbc",@"abcopjoj",@"abjoc",@"khujabc",@"abc9074",]; NSPredicate *predicate = [NSPredicate predicateWithFormat:@"SELF CONTAINS[cd] %@", @"abc"];NSArray *resultArr = [array filteredArrayUsingPredicate:predicate];NSLog(@"%@",resultArr);
  • 1
  • 2
  • 3
  • 4
  • 1
  • 2
  • 3
  • 4

谓词过滤的筛选条件

1.逻辑运算符号(> , < , = , >= , <=) 
还可以跟逻辑运算符一起使用的: &&, || ,AND, OR 谓词不区分大小写

NSPredicate *predicate = [NSPredicate predicateWithFormat:@"age > 20"];  
NSPredicate *predicate = [NSPredicate predicateWithFormat:@"height > 180 && age > 10"];  
NSPredicate *predicate = [NSPredicate predicateWithFormat:@"height > 180 OR age > 10"];
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3

2.范围运算符(IN,BETWEEN)

NSPredicate *predicate = [NSPredicate predicateWithFormat:"age BETWEEN {1,5}"];  
NSPredicate *predicate = [NSPredicate predicateWithFormat:@"name IN {'abc' , 'def' , '123'}"];  
  • 1
  • 2
  • 1
  • 2

3.字符串之开头和结尾(BEGINSWITH,ENDSWITH) 
BEGINSWITH:以**开头 
ENDSWITH:以**结尾

//name以N打头
NSPredicate *predicate = [NSPredicate predicateWithFormat:@"name BEGINSWITH 'N'"];  
NSPredicate *predicate = [NSPredicate predicateWithFormat:@"name BEGINSWITH[c] 'M'"];  
NSPredicate *predicate = [NSPredicate predicateWithFormat:@"name BEGINSWITH[d] 'C'"];  
NSPredicate *predicate = [NSPredicate predicateWithFormat:@"name BEGINSWITH[cd] 'w'"];  
  • 1
  • 2
  • 3
  • 4
  • 5
  • 1
  • 2
  • 3
  • 4
  • 5

注:字符串类的筛选条件中, [c]不区分大小写[d]不区分发音符号即没有重音符号[cd]既不区分大小写,也不区分发音符号。

4.字符串之包含和模糊查询(CONTAINS,LIKE) 
CONTAINS:包含某个字符串 
LIKE:模糊查询

NSPredicate *predicate = [NSPredicate predicateWithFormat:@"name CONTAINS 'N'"]; 
NSPredicate *predicate = [NSPredicate predicateWithFormat:@"name LIKE '*N*'"];
NSPredicate *predicate = [NSPredicate predicateWithFormat:@"name LIKE[cd] '???er*"];
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3

注:LIKE中的?表示一个任意字符, *表示通配符

5.字符串匹配查询(SELF) 
以上说的都是对象中的属性匹配的筛选条件,如果数组中都是字符串,即非属性匹配查询, 需要用到SELF.

    NSPredicate *predicate = [NSPredicate predicateWithFormat:@"SELF CONTAINS[cd] %@", @"abc"];
  • 1
  • 1

6.正则表达式(MATCHES) 
NSPredicate 使用MATCHES 匹配正则表达式,正则表达式的写法采用international components 
for Unicode (ICU)的正则语法。 

NSString *regex = @"^A.+e$";//以A 开头,以e 结尾的字符。  
NSPredicate *pre= [NSPredicate predicateWithFormat:@"SELF MATCHES %@", regex];  
  • 1
  • 2
  • 1
  • 2

举例

例一

NSArray *array=[NSArray arrayWithObjects:person1,person2,person3,person4,...,nil];  
//方法一:手动过滤出age小于20的person数组
NSPredicate *predicate = [NSPredicate predicateWithFormat:@"age < 20"];  
for(Person *person in array){  if([predicate evaluateWithObject:person]){ //判断指定的对象是否满足}  
}  
//方法二:直接获取过滤出age小于20的person数组
NSArray *persons = [array filteredArrayUsingPredicate:predicate];//获取所有age小于20的person 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

例二

将self.dataSourceArray模型数组中, 对 groupname 和 diseasename两个分别进行筛选, 将筛选模型添加到self.resulArr中, 并去重.

    NSPredicate *namePredicate = [NSPredicate predicateWithFormat:@"groupname CONTAINS[cd] %@",searchString];NSArray *nameArr = [self.dataSourceArray filteredArrayUsingPredicate:namePredicate];NSPredicate *diseasePredicate = [NSPredicate predicateWithFormat:@"diseasemc CONTAINS[cd] %@",searchString];NSArray *diseaseArr = [self.dataSourceArray filteredArrayUsingPredicate:diseasePredicate];NSMutableSet *set = [NSMutableSet setWithArray:nameArr];[set addObjectsFromArray:diseaseArr];self.resultArr = [set sortedArrayUsingDescriptors:@[[[NSSortDescriptor alloc] initWithKey:@"groupname" ascending:YES]]];
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

总结和注意

1.NSPredicate既适用于属性匹配,对数据模型或者dic进行过滤; 又适用于简单字符串的非属性匹配. 区别只是谓词的条件用法不同. 
2.在字符串筛选的谓词条件中, [c]不区分大小写[d]不区分发音符号即没有重音符号[cd]既不区分大小写,也不区分发音符号。 
3.在例子中, filteredArrayUsingPredicate语句是进行过滤的执行. 然后, 我们进入到NSPredicate类中, 可以发现, NSPredicateSupport对NSArray,NSMutableArray,NSSet,NSMutableSet,NSOrderedSet,NSMutableOrderedSet这些类都是适用的.

@interface NSArray<ObjectType> (NSPredicateSupport)
- (NSArray<ObjectType> *)filteredArrayUsingPredicate:(NSPredicate *)predicate;    // evaluate a predicate against an array of objects and return a filtered array
@end@interface NSMutableArray<ObjectType> (NSPredicateSupport)
- (void)filterUsingPredicate:(NSPredicate *)predicate;    // evaluate a predicate against an array of objects and filter the mutable array directly
@end@interface NSSet<ObjectType> (NSPredicateSupport)
- (NSSet<ObjectType> *)filteredSetUsingPredicate:(NSPredicate *)predicate NS_AVAILABLE(10_5, 3_0);    // evaluate a predicate against a set of objects and return a filtered set
@end@interface NSMutableSet<ObjectType> (NSPredicateSupport)
- (void)filterUsingPredicate:(NSPredicate *)predicate NS_AVAILABLE(10_5, 3_0);    // evaluate a predicate against a set of objects and filter the mutable set directly
@end@interface NSOrderedSet<ObjectType> (NSPredicateSupport)
- (NSOrderedSet<ObjectType> *)filteredOrderedSetUsingPredicate:(NSPredicate *)p NS_AVAILABLE(10_7, 5_0);    // evaluate a predicate against an ordered set of objects and return a filtered ordered set
@end@interface NSMutableOrderedSet<ObjectType> (NSPredicateSupport)
- (void)filterUsingPredicate:(NSPredicate *)p NS_AVAILABLE(10_7, 5_0);  // evaluate a predicate against an ordered set of objects and filter the mutable ordered set directly
@end
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23

这篇关于NSPredicate-谓词使用总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/663509

相关文章

Python通用唯一标识符模块uuid使用案例详解

《Python通用唯一标识符模块uuid使用案例详解》Pythonuuid模块用于生成128位全局唯一标识符,支持UUID1-5版本,适用于分布式系统、数据库主键等场景,需注意隐私、碰撞概率及存储优... 目录简介核心功能1. UUID版本2. UUID属性3. 命名空间使用场景1. 生成唯一标识符2. 数

SpringBoot中如何使用Assert进行断言校验

《SpringBoot中如何使用Assert进行断言校验》Java提供了内置的assert机制,而Spring框架也提供了更强大的Assert工具类来帮助开发者进行参数校验和状态检查,下... 目录前言一、Java 原生assert简介1.1 使用方式1.2 示例代码1.3 优缺点分析二、Spring Fr

Android kotlin中 Channel 和 Flow 的区别和选择使用场景分析

《Androidkotlin中Channel和Flow的区别和选择使用场景分析》Kotlin协程中,Flow是冷数据流,按需触发,适合响应式数据处理;Channel是热数据流,持续发送,支持... 目录一、基本概念界定FlowChannel二、核心特性对比数据生产触发条件生产与消费的关系背压处理机制生命周期

java使用protobuf-maven-plugin的插件编译proto文件详解

《java使用protobuf-maven-plugin的插件编译proto文件详解》:本文主要介绍java使用protobuf-maven-plugin的插件编译proto文件,具有很好的参考价... 目录protobuf文件作为数据传输和存储的协议主要介绍在Java使用maven编译proto文件的插件

Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式

《Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式》本文详细介绍如何使用Java通过JDBC连接MySQL数据库,包括下载驱动、配置Eclipse环境、检测数据库连接等关键步骤,... 目录一、下载驱动包二、放jar包三、检测数据库连接JavaJava 如何使用 JDBC 连接 mys

SpringBoot线程池配置使用示例详解

《SpringBoot线程池配置使用示例详解》SpringBoot集成@Async注解,支持线程池参数配置(核心数、队列容量、拒绝策略等)及生命周期管理,结合监控与任务装饰器,提升异步处理效率与系统... 目录一、核心特性二、添加依赖三、参数详解四、配置线程池五、应用实践代码说明拒绝策略(Rejected

C++ Log4cpp跨平台日志库的使用小结

《C++Log4cpp跨平台日志库的使用小结》Log4cpp是c++类库,本文详细介绍了C++日志库log4cpp的使用方法,及设置日志输出格式和优先级,具有一定的参考价值,感兴趣的可以了解一下... 目录一、介绍1. log4cpp的日志方式2.设置日志输出的格式3. 设置日志的输出优先级二、Window

Ubuntu如何分配​​未使用的空间

《Ubuntu如何分配​​未使用的空间》Ubuntu磁盘空间不足,实际未分配空间8.2G因LVM卷组名称格式差异(双破折号误写)导致无法扩展,确认正确卷组名后,使用lvextend和resize2fs... 目录1:原因2:操作3:报错5:解决问题:确认卷组名称​6:再次操作7:验证扩展是否成功8:问题已解

Qt使用QSqlDatabase连接MySQL实现增删改查功能

《Qt使用QSqlDatabase连接MySQL实现增删改查功能》这篇文章主要为大家详细介绍了Qt如何使用QSqlDatabase连接MySQL实现增删改查功能,文中的示例代码讲解详细,感兴趣的小伙伴... 目录一、创建数据表二、连接mysql数据库三、封装成一个完整的轻量级 ORM 风格类3.1 表结构

使用Docker构建Python Flask程序的详细教程

《使用Docker构建PythonFlask程序的详细教程》在当今的软件开发领域,容器化技术正变得越来越流行,而Docker无疑是其中的佼佼者,本文我们就来聊聊如何使用Docker构建一个简单的Py... 目录引言一、准备工作二、创建 Flask 应用程序三、创建 dockerfile四、构建 Docker