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