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
注:虽然大小写都可以,但是更推荐使用大写来表示这些保留字