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 | 代表逻辑真 |
保留字
下列单词都是保留字(不论大小写) AND
、OR
、IN
、NOT
、ALL
、ANY
、SOME
、NONE
、LIKE
、CASEINSENSITIVE
、CI
、 MATCHES
、CONTAINS
、BEGINSWITH
、ENDSWITH
、BETWEEN
、NULL
、NIL
、SELF
、 TRUE
、YES
、FALSE
、NO
、FIRST
、LAST
、SIZE
、ANYKEY
、SUBQUERY
、CAST
、 TRUEPREDICATE
、FALSEPREDICATE
注:虽然大小写都可以,但是更推荐使用大写来表示这些保留字