iOS 谓词的使用- 两个数组,过滤掉相同的数据

从第二个数组中去除与第一个数组中相同的元素

例:
listA = [1,2,3,4,5]
listB = [4,5,6,7]
listB 去除与listA 中重复的数据
获得 listC = [6,7]

可以用谓词NSPredicate, 2 行代码搞定


- (void)test{
    NSArray * testArr = @[4,5,6,7];
    NSArray * filterArr = @[1,2,3,4];
    [self filterSame: testArr filter:filterArr]; //[6,7]
}

- (NSArray *)filterSame:(NSArray *)items filter:(NSArray *)filterArr {
    NSPredicate *filterPredicate = [NSPredicate predicateWithFormat:@"NOT (SELF IN %@)", filterArr];
    return  [items filteredArrayUsingPredicate:filterPredicate];
}

NSPredicate 谓词用法 拓展

1.比较运算符

比较运算符如下

  • ===:判断两个表达式是否相等,在谓词中===是相同的意思都是判断,而没有赋值这一说
NSNumber *testNumber = @123;
 NSPredicate *predicate = [NSPredicate predicateWithFormat:@"SELF = 123"];
 if ([predicate evaluateWithObject:testNumber]) {
 NSLog(@"testString:%@", testNumber);
 }

我们可以看到输出的内容为:

2016-01-07 11:12:27.281 PredicteDemo[4130:80412] testString:123

  • >==>:判断左边表达式的值是否大于或等于右边表达式的值
  • <==<:判断左边表达式的值是否小于或等于右边表达式的值
  • >:判断左边表达式的值是否大于右边表达式的值
  • <:判断左边表达式的值是否小于右边表达式的值
  • !=<>:判断两个表达式是否不相等
  • BETWEEN:BETWEEN表达式必须满足表达式 BETWEEN {下限,上限}的格式,要求该表达式必须大于或等于下限,并小于或等于上限
NSNumber *testNumber = @123;
NSPredicate *predicate = [NSPredicate predicateWithFormat:@"SELF BETWEEN {100, 200}"];
 if ([predicate evaluateWithObject:testNumber]) {
 NSLog(@"testString:%@", testNumber);
 } else {
 NSLog(@"不符合条件");
 }

输出结果为:
2016-01-07 11:20:39.921 PredicteDemo[4366:85408] testString:123

2.逻辑运算符

  • AND&&:逻辑与,要求两个表达式的值都为YES时,结果才为YES。
 NSArray *testArray = @[@1, @2, @3, @4, @5, @6];
 NSPredicate *predicate = [NSPredicate predicateWithFormat:@"SELF > 2 && SELF < 5"];
 NSArray *filterArray = [testArray filteredArrayUsingPredicate:predicate];
 NSLog(@"filterArray:%@", filterArray);

输出结果为:
2016-01-07 11:27:01.885 PredicteDemo[4531:89537] filterArray:( 3, 4 )

  • OR||:逻辑或,要求其中一个表达式为YES时,结果就是YES
  • NOT!:逻辑非,对原有的表达式取反

3.字符串比较运算符

  • BEGINSWITH:检查某个字符串是否以指定的字符串开头(如判断字符串是否以a开头:BEGINSWITH 'a')
  • ENDSWITH:检查某个字符串是否以指定的字符串结尾
  • CONTAINS:检查某个字符串是否包含指定的字符串
  • LIKE:检查某个字符串是否匹配指定的字符串模板。其之后可以跟?代表一个字符和*代表任意多个字符两个通配符。比如"name LIKE '*ac*'",这表示name 的值中包含a c则返回YES"name LIKE '?ac*'",表示name 的第2、3个字符为ac时返回YES
  • MATCHES:检查某个字符串是否匹配指定的正则表达式。虽然正则表达式的执行效率是最低的,但其功能是最强大的,也是我们最常用的。

注:字符串比较都是区分大小写和重音符号的。

4.集合运算符

  • ANYSOME:集合中任意一个元素满足条件,就返回YES。
  • ALL:集合中所有元素都满足条件,才返回YES。
  • NONE:集合中没有任何元素满足条件就返回YES。如:NONE person.age < 18,表示person集合中所有元素的age>=18时,才返回YES。
  • IN:等价于SQL语句中的IN运算符,只有当左边表达式或值出现在右边的集合中才会返回YES。我们通过一个例子来看一下
NSArray *filterArray = @[@"ab", @"abc"];
 NSArray *array = @[@"a", @"ab", @"abc", @"abcd"];
 NSPredicate *predicate = [NSPredicate predicateWithFormat:@"NOT (SELF IN %@)", filterArray];
 NSLog(@"%@", [array filteredArrayUsingPredicate:predicate]);

代码的作用是将array中和filterArray中相同的元素去除
输出为:
2016-01-07 13:17:43.669 PredicteDemo[6701:136206] ( a, abcd )

5.直接量

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

  • FALSENO:代表逻辑假
  • TRUEYES:代表逻辑真
  • NULLNIL:代表空值
  • SELF:代表正在被判断的对象自身
  • "string"'string':代表字符串
  • 数组:和c中的写法相同,如:{'one', 'two', 'three'}。
  • 数值:包括证书、小数和科学计数法表示的形式
  • 十六进制数:0x开头的数字
  • 八进制:0o开头的数字
  • 二进制:0b开头的数字

6.保留字

下列单词都是保留字(不论大小写)
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

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

你可能感兴趣的:(iOS 谓词的使用- 两个数组,过滤掉相同的数据)