OC_NSPredicate(谓词)

307 阅读4分钟

NSPredicate类是一个用来定义逻辑条件约束的类。 可以使用谓词来表示逻辑条件,对内存中的对象进行过滤。

NSPredicate示例

创建方法

首先我们需要创建一个 NSPredicate 对象,然后定义它的逻辑条件, 创建使用的方法如下:

+ (NSPredicate *)predicateWithFormat:(NSString *)predicateFormat, ...;

eg.

NSPredicate *predicate = [NSPredicate predicateWithFormat:@"SELF.intValue > 10"];
//定义了一个逻辑条件,条件为字符串的 intValue 值大于 10

过滤方法

第一种简单的使用方法是使用方法:

- (BOOL)evaluateWithObject:(nullable id)object;

此方法通过创建的NSPredicate对象调用,并根据定义的规则对传入的对象进行判断,如果符合规则,返回 YES ,不符合返回 NO

例如:

NSPredicate *predictae = [NSPredicate predicateWithFormat:@"SELF.intValue > 10"];
BOOL result = [predictae evaluateWithObject:@"15"];
// result 的值为 YES

第二种使用方法,一般在进行过滤时会将要过滤的数据保存到一个数组之中,然后调用数组的对象方法进行过滤:

- (NSArray<ObjectType> *)filteredArrayUsingPredicate:(NSPredicate *)predicate;

该方法会过滤掉数组内不符合条件的元素,并将符合条件的元素以数组的形式返回。

完整示例代码:

NSPredicate *predictae = [NSPredicate predicateWithFormat:@"SELF.intValue > 10"];
NSArray *arr = @[@"0",@"5",@"10",@"15",@"20"];
NSArray *arr1 = [arr filteredArrayUsingPredicate:predictae];
NSLog(@"%@",arr1);

打印结果为 ( 15 , 20 )

NSPredicate 语法

只要我们使用NSPredicate都需要为谓词定义谓词表达式,而这个表达式必须是一个返回 BOOL 的值。谓词表达式由表达式、运算符和值构成。

比较运算符

运算符 解释
=== 判断两个表达式是否相等,在谓词中===是相同的意思都是判断而没有 赋值这一说
>==> 判断左边表达式的值是否大于或等于右边表达式的值
<==< 判断右边表达式的值是否小于或等于右边表达式的值
> 判断左边表达式的值是否大于右边表达式的值
< 判断左边表达式的值是否小于右边表达式的值
!=<> 判断两个表达式是否不相等
BETWEEN BETWEEN表达式必须满足表达式BETWEEN {下限,上限}的格式,要求该表达式必须大于或等于下限,并小于或等于上限

逻辑运算符

运算符 解释
AND&& 逻辑与,要求两个表达式的值都为 YES 时,结果才为 YES
OR|| 逻辑或,要求其中一个表达式为 YES 时,结果就是 YES
NOT! 逻辑非,对原有的表达式取反

字符串比较运算符

运算符 解释
BEGINSWITH 检查某个字符串是否以指定的字符串开头(如判断字符串是否以 a 开 头:BEGINSWITH 'a')
ENDSWITH 检查某个字符串是否以指定的字符串结尾
CONTAINS 检查某个字符串是否包含指定的字符串
LIKE 检查某个字符串是否匹配指定的字符串模板。
MATCHES 检查某个字符串是否匹配指定的正则表达式,虽然正则表达式的执行效率是最低的,但其功能是最强大的也是我们最常用的。

LIKE的用法

LIKE 之后可以跟 ? 代表一个字符和 * 代表任意多个字符两个通配符,如

"name LIKE '*ac*'"

这表示 name 的值中包含 ac 则返回 YES,反之返回NO

"name LIKE '?ac*'"

表示 name 的第 2、3 个字符为 ac 时返回 YES,反之返回NO

集合运算符

运算符 解释
ANY、SOME 集合中任意一个元素满足条件,就返回 YES
ALL 集合中所有元素都满足条件,才返回 YES
NONE 集合中没有任何元素满足条件就返回 YES。如:NONE person.age < 18,表示 person 集合中所有元素的 age>=18 时,才返回 YES
IN 等价于SQL语句中的 IN 运算符,只有当左边表达式或值出现在右边的集合中才会返回 YES
arr[index] 返回数组中 index 索引处的元素
arr[FIRST] 返回数组中第一个元素
arr[LAST] 返回数组中最后一个元素
arr[SIZE] 返回数组中元素的个数

直接量

在谓词表达式中可以使用如下直接量

直接量 解释
FALSE、NO 代表逻辑假
NULL、NIL 代表空值
SELF 代表正在被判断的对象自身
"string"或'string' 代表字符串数组和C中的写法相同,如{'one', 'two', 'three'}数值包括证书、小数和科学计数法表示的形式
十六进制数 0x 开头的数字
八进制 0o 开头的数字
二进制 0b 开头的数字
TRUE、YES 代表逻辑真

保留字

下列单词都是保留字(不论大小写) ANDORINNOTALLANYSOMENONELIKECASEINSENSITIVECIMATCHESCONTAINSBEGINSWITHENDSWITHBETWEENNULLNILSELFTRUEYESFALSENOFIRSTLASTSIZEANYKEYSUBQUERYCASTTRUEPREDICATEFALSEPREDICATE

注:虽然大小写都可以,但是更推荐使用大写来表示这些保留字