NSPredicate iOS oc 谓词简单用法 数据过滤之类的等等

NSString *phoneNum = @"abcd";
NSString *regx = @"^1[358][0-9]{9}$";
NSPredicate *pre = [NSPredicate predicateWithFormat:@"SELF MATCHES %@",regx];
BOOL invalue = [pre evaluateWithObject:phoneNum];
NSLog(@"%@",invalue?@"YES":@"NO");

       这是一个用来验证手机号格式是否正确的一段代码,html

       简单介绍NSPredicate,这种语句就像sql语句同样,指定了数据被过滤或者获取的方式。了解sql语句的孩子会以为很简单。ios

上面那段代码刚开始看可能有点不理解,没事,按部就班,看完这篇文章就懂了正则表达式

所谓数据过滤或者获取,就是从一段数据中,好比"哈哈哈哈哈1234567898423哈哈哈哈哈哈"中找到那段数字。sql

 

 

(一)首先了解语句的构成    数据库

  想要查找数据的时候,好比在某张公司员工的表格中查找叫“曹国芳”的人的年龄,是这样表示的 “select age(表里的元素)  from  infoTable(表名)  where  name = '曹国芳'”      翻译成中文大约是,查出来年龄 从那张信息表里 在名字=曹国芳的那条,这样翻译可能有些直白,可是可让没接触过sql语句的人能听懂我在说什么。  而谓词呢,更为简洁,由于没有涉及到数据库以及表格,因此在用起来也是几行代码就能办到。数组

因此在使用NSPredicate的时候,也有不少判断条件lua

 

1,比较运算符spa

 (1)=、==:判断两个表达式是否相等,在谓词中=和==是相同的意思都是判断,而没有赋值这一说咱们能够看到输出的内容为翻译

(2)>=,=>:判断左边表达式的值是否大于或等于右边表达式的值code

(3)<=,=<:判断右边表达式的值是否小于或等于右边表达式的值

(4)>:判断左边表达式的值是否大于右边表达式的值

(5)<:判断左边表达式的值是否小于右边表达式的值

(6)!=、<>:判断两个表达式是否不相等

(7)BETWEEN:BETWEEN表达式必须知足表达式 BETWEEN {下限,上限}的格式,要求该表达式必须大于或等于下限,并小于或等于上限

比较运算符使用起来是这样的

NSString *phoneNum = @"123";
NSPredicate *pre = [NSPredicate predicateWithFormat:@"SELF = 123"];
BOOL invalue = [pre evaluateWithObject:phoneNum];
NSLog(@"%@",invalue?@"YES":@"NO");

就算是BETWEEN 用起来就能够这么改  'SELF BETWEEN {10,20}' 判断是否这个数字在10-20之间

2.逻辑运算符

(1)AND、&&:逻辑与,要求两个表达式的值都为YES时,结果才为YES。

输出结果为:

(2)OR、||:逻辑或,要求其中一个表达式为YES时,结果就是YES

(3)NOT、 !:逻辑非,对原有的表达式取反

3.字符串比较运算符

(1)BEGINSWITH:检查某个字符串是否以指定的字符串开头(如判断字符串是否以a开头:BEGINSWITH 'a')

(2)ENDSWITH:检查某个字符串是否以指定的字符串结尾

(3)CONTAINS:检查某个字符串是否包含指定的字符串

(4)LIKE:检查某个字符串是否匹配指定的字符串模板。其以后能够跟?表明一个字符和*表明任意多个字符两个通配符。好比"name LIKE '*ac*'",这表示name的值中包含ac则返回YES;"name LIKE '?ac*'",表示name的第二、3个字符为ac时返回YES。

(5)MATCHES:检查某个字符串是否匹配指定的正则表达式。虽然正则表达式的执行效率是最低的,但其功能是最强大的,也是咱们最经常使用的。这也就是我在文章刚开头那么用的

  注:字符串比较都是区分大小写和重音符号的。如:café和cafe是不同的,Cafe和cafe也是不同的。若是但愿字符串比较运算不区分大小写和重音符号,请在这些运算符后使用[c],[d]选项。其中[c]是不区分大小写,[d]是不区分重音符号,其写在字符串比较运算符以后,好比:name LIKE[cd] 'cafe',那么不论name是cafe、Cafe仍是café上面的表达式都会返回YES

4.集合运算符

(1)ANY、SOME:集合中任意一个元素知足条件,就返回YES。

(2)ALL:集合中全部元素都知足条件,才返回YES。

(3)NONE:集合中没有任何元素知足条件就返回YES。如:NONE person.age < 18,表示person集合中全部元素的age>=18时,才返回YES。

(4)IN:等价于SQL语句中的IN运算符,只有当左边表达式或值出如今右边的集合中才会返回YES。咱们经过一个例子来看一下

(5)array[index]:返回array数组中index索引处的元素

(6)array[FIRST]:返回array数组中第一个元素

(7)array[LAST]:返回array数组中最后一个元素

(8)array[SIZE]:返回array数组中元素的个数

5.直接量

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

(1)FALSE、NO:表明逻辑假

(2)TRUE、YES:表明逻辑真

(3)NULL、NIL:表明空值

(4)SELF:表明正在被判断的对象自身

(5)"string"或'string':表明字符串

(6)数组:和c中的写法相同,如:{'one', 'two', 'three'}。

(7)数值:包括证书、小数和科学计数法表示的形式

(8)十六进制数:0x开头的数字

(9)八进制:0o开头的数字

(10)二进制: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

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

 

 

(二)NSPredicate 使用方

1.正则表达式   当使用NSRegularExpression使用正则表达式时,若是验证手机号,用它“1[358][0-9]{9}”就能够了,可是若是用NSPredicate来使用正则表达式,有点瑕疵,须要按照"^正则表达式$"来使用才不会出现有可能判断失误的问题

2.使用谓词过滤集合 (划重点)

当程序使用谓词对集合元素进行过滤时,程序会自动遍历其元素,并根据集合元素来计算谓词的值,当这个集合中的元素计算谓词并返回YES时,这个元素才会被保留下来。请注意程序会自动遍历其元素,它会将自动遍历过以后返回为YES的值从新组合成一个集合返回。

(1)NSArray提供了以下方法使用谓词来过滤集合

- (NSArray*)filteredArrayUsingPredicate:(NSPredicate *)predicate:使用指定的谓词过滤NSArray集合,返回符合条件的元素组成的新集合

(2)NSMutableArray提供了以下方法使用谓词来过滤集合

- (void)filterUsingPredicate:(NSPredicate *)predicate:使用指定的谓词过滤NSMutableArray,剔除集合中不符合条件的元素

(3)NSSet提供了以下方法使用谓词来过滤集合

- (NSSet*)filteredSetUsingPredicate:(NSPredicate *)predicate NS_AVAILABLE(10_5, 3_0):做用同NSArray中的方法

(4)NSMutableSet提供了以下方法使用谓词来过滤集合

- (void)filterUsingPredicate:(NSPredicate *)predicate NS_AVAILABLE(10_5, 3_0):做用同NSMutableArray中的方法。

经过上面的描述能够看出,使用谓词过滤不可变集合和可变集合的区别是:过滤不可变集合时,会返回符合条件的集合元素组成的新集合;过滤可变集合时,没有返回值,会直接剔除不符合条件的集合元素

 

具体实例请参考原创做者的http://www.cocoachina.com/ios/20160111/14926.html

相关文章
相关标签/搜索