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

相关文章

详解Vue如何使用xlsx库导出Excel文件

《详解Vue如何使用xlsx库导出Excel文件》第三方库xlsx提供了强大的功能来处理Excel文件,它可以简化导出Excel文件这个过程,本文将为大家详细介绍一下它的具体使用,需要的小伙伴可以了解... 目录1. 安装依赖2. 创建vue组件3. 解释代码在Vue.js项目中导出Excel文件,使用第三

Kubernetes常用命令大全近期总结

《Kubernetes常用命令大全近期总结》Kubernetes是用于大规模部署和管理这些容器的开源软件-在希腊语中,这个词还有“舵手”或“飞行员”的意思,使用Kubernetes(有时被称为“... 目录前言Kubernetes 的工作原理为什么要使用 Kubernetes?Kubernetes常用命令总

Linux alias的三种使用场景方式

《Linuxalias的三种使用场景方式》文章介绍了Linux中`alias`命令的三种使用场景:临时别名、用户级别别名和系统级别别名,临时别名仅在当前终端有效,用户级别别名在当前用户下所有终端有效... 目录linux alias三种使用场景一次性适用于当前用户全局生效,所有用户都可调用删除总结Linux

java图像识别工具类(ImageRecognitionUtils)使用实例详解

《java图像识别工具类(ImageRecognitionUtils)使用实例详解》:本文主要介绍如何在Java中使用OpenCV进行图像识别,包括图像加载、预处理、分类、人脸检测和特征提取等步骤... 目录前言1. 图像识别的背景与作用2. 设计目标3. 项目依赖4. 设计与实现 ImageRecogni

python管理工具之conda安装部署及使用详解

《python管理工具之conda安装部署及使用详解》这篇文章详细介绍了如何安装和使用conda来管理Python环境,它涵盖了从安装部署、镜像源配置到具体的conda使用方法,包括创建、激活、安装包... 目录pytpshheraerUhon管理工具:conda部署+使用一、安装部署1、 下载2、 安装3

Mysql虚拟列的使用场景

《Mysql虚拟列的使用场景》MySQL虚拟列是一种在查询时动态生成的特殊列,它不占用存储空间,可以提高查询效率和数据处理便利性,本文给大家介绍Mysql虚拟列的相关知识,感兴趣的朋友一起看看吧... 目录1. 介绍mysql虚拟列1.1 定义和作用1.2 虚拟列与普通列的区别2. MySQL虚拟列的类型2

使用MongoDB进行数据存储的操作流程

《使用MongoDB进行数据存储的操作流程》在现代应用开发中,数据存储是一个至关重要的部分,随着数据量的增大和复杂性的增加,传统的关系型数据库有时难以应对高并发和大数据量的处理需求,MongoDB作为... 目录什么是MongoDB?MongoDB的优势使用MongoDB进行数据存储1. 安装MongoDB

关于@MapperScan和@ComponentScan的使用问题

《关于@MapperScan和@ComponentScan的使用问题》文章介绍了在使用`@MapperScan`和`@ComponentScan`时可能会遇到的包扫描冲突问题,并提供了解决方法,同时,... 目录@MapperScan和@ComponentScan的使用问题报错如下原因解决办法课外拓展总结@

mysql数据库分区的使用

《mysql数据库分区的使用》MySQL分区技术通过将大表分割成多个较小片段,提高查询性能、管理效率和数据存储效率,本文就来介绍一下mysql数据库分区的使用,感兴趣的可以了解一下... 目录【一】分区的基本概念【1】物理存储与逻辑分割【2】查询性能提升【3】数据管理与维护【4】扩展性与并行处理【二】分区的

使用Python实现在Word中添加或删除超链接

《使用Python实现在Word中添加或删除超链接》在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能,本文将为大家介绍一下Python如何实现在Word中添加或... 在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能。通过添加超