NSPredicate 谓语正则

2018-07-23  本文已影响81人  DDY
元字符
元字符 描述
\ 将下个字符标记符或一个向后引用或一个八进制转义符。例,“\n”匹配\n。“\n”匹配换行符。“\”匹配\
^ 匹配输入字符串的开始位置。如果设置了RegExp对象的Multiline属性,^也匹配“\n”或“\r”之后的位置
$ 匹配输入字符串的结束位置。如果设置了RegExp对象的Multiline属性,$也匹配“\n”或“\r”之前的位置
* 匹配前面的子表达式任意次。例如,zo能匹配“z”,“zo”以及“zoo”,但是不匹配“bo”。等价于{0,}
+ 匹配前面的子表达式一次或多次(大于等于1次)。例,“zo+”能匹配“zo”以及“zoo”,但不能匹配“z”。+等价于{1,}
? 匹配前面的子表达式零次或一次。例如,“do(es)?”可以匹配“do”或“does”中的“do”。?等价于{0,1}
{n} n是一个非负整数。匹配确定的n次。例如,“o{2}”不能匹配“Bob”中的“o”,但是能匹配“food”中的两个o
{n,} n是一个非负整数。至少匹配n次。例如,“o{2,}”不能匹配“Bob”中的“o”,但能匹配“foooood”中的所有o。“o{1,}”等价于“o+”。“o{0,}”则等价于“o*”
{n,m} m和n均为非负整数,其中n<=m。最少匹配n次且最多匹配m次。例如,“o{1,3}”将匹配“fooooood”中的前三个o。“o{0,1}”等价于“o?”。请注意在逗号和两个数之间不能有空格
? 当该字符紧跟在任何一个其他限制符(*,+,?,{n},{n,},{n,m})后面时,匹配模式是非贪婪的。非贪婪模式尽可能少的匹配所搜索的字符串,而默认的贪婪模式则尽可能多的匹配所搜索的字符串。例如,对于字符串“oooo”,“o+?”将匹配单个“o”,而“o+”将匹配所有“o”
.点 匹配除“\r\n”之外的任何单个字符。要匹配包括“\r\n”在内的任何字符,请使用像“[\s\S]”的模式
(pattern) 匹配pattern并获取这一匹配。所获取的匹配可以从产生的Matches集合得到,在VBScript中使用SubMatches集合,在JScript中则使用0…9属性。要匹配圆括号字符,请使用“(”或“)”
(?:pattern) 非获取匹配,匹配pattern但不获取匹配结果,不进行存储供以后使用。这在使用或字符“(|)”来组合一个模式的各个部分是很有用。例如“industr(?:y|ies)”就是一个比“industry|industries”更简略的表达式
(?=pattern) 非获取匹配,正向肯定预查,在任何匹配pattern的字符串开始处匹配查找字符串,该匹配不需要获取供以后使用。例如,“Windows(?=95|98|NT|2000)”能匹配“Windows2000”中的“Windows”,但不能匹配“Windows3.1”中的“Windows”。预查不消耗字符,也就是说,在一个匹配发生后,在最后一次匹配之后立即开始下一次匹配的搜索,而不是从包含预查的字符之后开始
(?!pattern) 非获取匹配,正向否定预查,在任何不匹配pattern的字符串开始处匹配查找字符串,该匹配不需要获取供以后使用。例如“Windows(?!95|98|NT|2000)”能匹配“Windows3.1”中的“Windows”,但不能匹配“Windows2000”中的“Windows”
(?<=pattern) 非获取匹配,反向肯定预查,与正向肯定预查类似,只是方向相反。例如,“(?<=95|98|NT|2000)Windows”能匹配“2000Windows”中的“Windows”,但不能匹配“3.1Windows”中的“Windows”。
(?<!pattern) 非获取匹配,反向否定预查,与正向否定预查类似,只是方向相反。例如“(?<!95|98|NT|2000)Windows”能匹配“3.1Windows”中的“Windows”,但不能匹配“2000Windows”中的“Windows”。这个地方不正确,有问题
x|y 匹配x或y。例如,“z|food”能匹配“z”或“food”(此处请谨慎)。“(z|f)ood”则匹配“zood”或“food”
[xyz] 字符集合。匹配所包含的任意一个字符。例如,“[abc]”可以匹配“plain”中的“a”
[^xyz] 负值字符集合。匹配未包含的任意字符。例如,“[^abc]”可以匹配“plain”中的“plin”
[a-z] 字符范围。匹配指定范围内的任意字符。例如,“[a-z]”可以匹配“a”到“z”范围内的任意小写字母字符
注意:只有连字符在字符组内部时,并且出现在两个字符之间时,才能表示字符的范围; 如果出字符组的开头,则只能表示连字符本身
[^a-z] 负值字符范围。匹配任何不在指定范围内的任意字符。例如,“[^a-z]”可以匹配任何不在“a”到“z”范围内的任意字符
\b 匹配一个单词边界,也就是指单词和空格间的位置(即正则表达式的“匹配”有两种概念,一种是匹配字符,一种是匹配位置,这里的\b就是匹配位置的)。例如,“er\b”可以匹配“never”中的“er”,但不能匹配“verb”中的“er”
\B 匹配非单词边界。“er\B”能匹配“verb”中的“er”,但不能匹配“never”中的“er”
\cx 匹配由x指明的控制字符。例如,\cM匹配一个Control-M或回车符。x的值必须为A-Z或a-z之一。否则,将c视为一个原义的“c”字符
\d 匹配一个数字字符。等价于[0-9]
\D 匹配一个非数字字符。等价于[^0-9]
\f 匹配一个换页符。等价于\x0c和\cL
\n 匹配一个换行符。等价于\x0a和\cJ
\r 匹配一个回车符。等价于\x0d和\cM
\s 匹配任何不可见字符,包括空格、制表符、换页符等等。等价于[ \f\n\r\t\v]
\S 匹配任何可见字符。等价于[^ \f\n\r\t\v]
\t 匹配一个制表符。等价于\x09和\cI
\v 匹配一个垂直制表符。等价于\x0b和\cK
\w 匹配包括下划线的任何单词字符。类似但不等价于“[A-Za-z0-9_]”,这里的"单词"字符使用Unicode字符集
\W 匹配任何非单词字符。等价于“[^A-Za-z0-9_]”
\xn 匹配n,其中n为十六进制转义值。十六进制转义值必须为确定的两个数字长。例如,“\x41”匹配“A”。“\x041”则等价于“\x04&1”。正则表达式中可以使用ASCII编码
\num 匹配num,其中num是一个正整数。对所获取的匹配的引用。例如,“(.)\1”匹配两个连续的相同字符
\n 标识一个八进制转义值或一个向后引用。如果\n之前至少n个获取的子表达式,则n为向后引用。否则,如果n为八进制数字(0-7),则n为一个八进制转义值
\nm 标识一个八进制转义值或一个向后引用。如果\nm之前至少有nm个获得子表达式,则nm为向后引用。如果\nm之前至少有n个获取,则n为一个后跟文字m的向后引用。如果前面的条件都不满足,若n和m均为八进制数字(0-7),则\nm将匹配八进制转义值nm
\nml 如果n为八进制数字(0-7),且m和l均为八进制数字(0-7),则匹配八进制转义值nml
\un 匹配n,其中n是一个用四个十六进制数字表示的Unicode字符。例如,\u00A9匹配版权符号(©)
\p{P} 小写 p 是 property 的意思,表示 Unicode 属性,用于 Unicode 正表达式的前缀。中括号内的“P”表示Unicode 字符集七个字符属性之一:标点字符
其他六个属性:
L:字母;
M:标记符号(一般不会单独出现);
Z:分隔符(比如空格、换行等);
S:符号(比如数学符号、货币符号等);
N:数字(比如阿拉伯数字、罗马数字等);
C:其他字符。
*注:此语法部分语言不支持,例:javascript。
< > 匹配词(word)的开始(<)和结束(>)。例如正则表达式<the>能够匹配字符串"for the wise"中的"the",但是不能匹配字符串"otherwise"中的"the"。注意:这个元字符不是所有的软件都支持的
( ) 将( 和 ) 之间的表达式定义为“组”(group),并且将匹配这个表达式的字符保存到一个临时区域(一个正则表达式中最多可以保存9个),它们可以用 \1 到\9 的符号来引用
| 将两个匹配条件进行逻辑“或”(Or)运算。例如正则表达式(him|her) 匹配"it belongs to him"和"it belongs to her",但是不能匹配"it belongs to them."。注意:这个元字符不是所有的软件都支持的
+ 匹配1或多个正好在它之前的那个字符。例如正则表达式9+匹配9、99、999等。注意:这个元字符不是所有的软件都支持的
? 匹配0或1个正好在它之前的那个字符。注意:这个元字符不是所有的软件都支持的
{i} {i,j} 匹配指定数目的字符,这些字符是在它之前的表达式定义的。例如正则表达式A[0-9]{3} 能够匹配字符"A"后面跟着正好3个数字字符的串,例如A123、A348等,但是不匹配A1234。而正则表达式[0-9]{4,6} 匹配连续的任意4个、5个或者6个数字
常用正则
作用 正则 评注
匹配中文字符 [u4e00-u9fa5] 匹配中文还真是个头疼的事,有了这个表达式就好办了
匹配双字节字符(包括汉字在内) [^x00-xff] 可以用来计算字符串的长度(一个双字节字符长度计2,ASCII字符计1)
匹配空白行 ns*r 可以用来删除空白行
匹配HTML标记 <(S?)[^>]>.?|<.? /> 网上流传的版本太糟糕,上面这个也仅仅能匹配部分,对于复杂的嵌套标记依旧无能为力
匹配首尾空白字符 ^s|s$ 可以用来删除行首行尾的空白字符(包括空格、制表符、换页符等等),非常有用的表达式
匹配Email地址 w+([-+.]w+)@w+([-.]w+).w+([-.]w+)* 表单验证时很实用
匹配网址URL [a-zA-z]+://[^s]* 网上流传的版本功能很有限,上面这个基本可以满足需求
匹配帐号是否合法(字母开头,允许5-16字节,允许字母数字下划线) ^[a-zA-Z][a-zA-Z0-9_]{4,15}$ 表单验证时很实用
匹配国内电话号码 d{3}-d{8}|d{4}-d{7} 匹配形式如 0511-4405222 或 021-87888822
匹配腾讯QQ号 [1-9][0-9]{4,} 腾讯QQ号从10000开始
匹配中国邮政编码 [1-9]d{5}(?!d) 中国邮政编码为6位数字
匹配身份证 d{15}|d{18} 中国的身份证为15位或18位
匹配ip地址 d+.d+.d+.d+ 评注:提取ip地址时有用
作用 正则
正整数 ^[1-9]d*$
负整数 ^-[1-9]d*$
整数 ^-?[1-9]d*$
非负整数 ^[1-9]d*|0$
非正整数 ^-[1-9]d*|0$
正浮点数 ^[1-9]d.d|0.d[1-9]d$
负浮点数 ^-([1-9]d.d|0.d[1-9]d)$
浮点数 ^-?([1-9]d.d|0.d[1-9]d|0?.0+|0)$
非负浮点数 ^[1-9]d.d|0.d[1-9]d|0?.0+|0$
非正浮点数 ^(-([1-9]d.d|0.d[1-9]d))|0?.0+|0$
26个英文字母组成字符串 ^[A-Za-z]+$
26个英文大写字母组成字符串 ^[A-Z]+$
26个英文小写字母组成字符串 ^[a-z]+$
数字和英文字母组成字符串 ^[A-Za-z0-9]+$
数字、字母或下划线组成字符串 ^w+$
只能输入数字 “^[0-9]*$”
只能输入n位的数字 “^d{n}$”
只能输入至少n位数字 “^d{n,}$”
只能输入m-n位的数字 “^d{m,n}$”
只能输入零和非零开头的数字 “^(0|[1-9][0-9]*)$”
只能输入有两位小数的正实数 “^[0-9]+(.[0-9]{2})?$”
只能输入有1-3位小数的正实数 “^[0-9]+(.[0-9]{1,3})?$”
只能输入非零的正整数 “^+?[1-9][0-9]*$”
只能输入非零的负整数 “^-[1-9][0-9]*$”
只能输入长度为3的字符 “^.{3}$”
只能输入由26个英文字母组成的字符串 “^[A-Za-z]+$”
只能输入由26个大写英文字母组成的字符串 “^[A-Z]+$”
只能输入由26个小写英文字母组成的字符串 “^[a-z]+$”
只能输入由数字和26个英文字母组成的字符串 “^[A-Za-z0-9]+$”
只能输入由数字、26个英文字母或者下划线组成的字符串 “^w+$”
验证用户密码
格式为:以字母开头,长度在6-18之间,只能包含字符、数字和下划线
“^[a-zA-Z]w{5,17}$”
验证是否含有^%&'',;=?$"等字符 “[^%&'',;=?$x22]+”
只能输入汉字 “^[u4e00-u9fa5],{0,}$”
Email地址 “^w+[-+.]w+)@w+([-.]w+).w+([-.]w+)*$”
InternetURL “^http://([w-]+.)+[w-]+(/[w-./?%&=]*)?$”
电话号码
格式为:
“XXXX-XXXXXXX”,
“XXXX-XXXXXXXX”,
“XXX-XXXXXXX”,
“XXX-XXXXXXXX”,
“XXXXXXX”,
“XXXXXXXX”
“^((d{3,4})|d{3,4}-)?d{7,8}$”
验证身份证号(15位或18位数字) “^d{15}|d{}18$”
验证一年的12个月
正确格式为:“01”-“09”和“1”“12”
“^(0?[1-9]|1[0-2])$”
验证一个月的31天 “^((0?[1-9])|((1|2)[0-9])|30|31)$”
正确格式为 “01”“09”和“1”“31”
匹配中文字符的正则表达式 [u4e00-u9fa5]
匹配双字节字符(包括汉字在内) [^x00-xff]
匹配空行的正则表达式 n[s| ]*r
匹配HTML标记的正则表达式 /<(.)>.|<(.*) />/
匹配首尾空格的正则表达式 (^s)|(s$)
匹配Email地址的正则表达式 w+([-+.]w+)@w+([-.]w+).w+([-.]w+)*
匹配网址URL http://([w-]+.)+[w-]+(/[w- ./?%&=]*)?

例如:判断是否是合法的整数或浮点数
NSString regex = @"^-?([1-9]d|[1-9]d.d|0.d[1-9]d|0?.0+|0)$";
NSPredicate *pred = [NSPredicate predicateWithFormat:@"SELF MATCHES %@",regex];
BOOL result = [pred evaluateWithObject:@"要判断的string"];

NSPredicate的用法

一个循环

NSMutableArray *filterArray = [NSMutableArray arrayWithObjects:@"pict", @"blackrain", @"ip", nil];
NSMutableArray *contentArray = [NSMutableArray arrayWithObjects:@"I am a picture.", @"I am a guy", @"I am gagaga", @"ipad", @"iphone", nil];
for (NSString *tempFilter in filterArray) {
  NSPredicate *filterPredicate = [NSPredicate predicateWithFormat:@"SELF CONTAINS %@", tempFilter];
  NSArray *tempResultArray = [contentArray filteredArrayUsingPredicate:filterPredicate];
  NSLog(@"result:%@",tempResultArray);
}

无需循环 过滤出来不包含filterArray中的所有item的元素。

NSMutableArray *filterArray = [NSMutableArray arrayWithObjects:@"abc1", @"abc2", nil];
NSMutableArray *contentArray = [NSMutableArray arrayWithObjects:@"a1", @"abc1", @"abc4", @"abc2", nil];
NSPredicate *thePredicate = [NSPredicate predicateWithFormat:@"NOT (SELF in %@)", filterArray];
[contentArray filterUsingPredicate:thePredicate];

1) 当使用聚合类的操作符(SELF in 集合操作符)时是可以不需要循环的
2)当使用单个比较类(CONTAINS 字符串比较操作符)的操作符时可以一个循环来搞定 CONTAINS

// 生成文件路径下文件集合列表
NSString *defaultPath = [[NSBundle mainBundle] resourcePath];
NSArray *contentsDict = [[NSFileManager defaultManager] contentsOfDirectoryAtPath:defaultPath error:nil];

// 简单比较
NSString *match = @"ddyImg-999.png";
NSPredicate *predicate = [NSPredicate predicateWithFormat:@"SELF == %@", match];
NSArray *results1 = [contentsDict filteredArrayUsingPredicate:predicate];
// match里like的用法(类似Sql中的用法)
NSString *match = @"ddyImg-*.png";
NSPredicate *predicate = [NSPredicate predicateWithFormat:@"SELF like %@", match];
NSArray *results2 = [directoryContents filteredArrayUsingPredicate:predicate];
// 大小写比较 [c]表示忽略大小写,[d]表示忽略重音,可以在一起使用,如下:
NSString *match = @"ddyImg-*.png";
NSPredicate *predicate = [NSPredicate predicateWithFormat:@"SELF like[cd] %@", match];
NSArray *results3 = [directoryContents filteredArrayUsingPredicate:predicate];
// 使用正则
NSString *match = @"ddyImg-\\d{3}\\.png";  //ddyImg-123.png
NSPredicate *predicate = [NSPredicate predicateWithFormat:@"SELF matches %@", match];
NSArray *results4 = [directoryContents filteredArrayUsingPredicate:predicate];
实际应用
NSArray *array = [[NSArray alloc]initWithObjects:@"beijing",@"shanghai",@"guangzou",@"wuhan", nil];    
NSString *string = @"ang";    
NSPredicate *pred = [NSPredicate predicateWithFormat:@"SELF CONTAINS %@",string];    
NSLog(@"%@",[array filteredArrayUsingPredicate:pred]);
NSString *regex = @"[A-Za-z]+";    
NSPredicate *predicate = [NSPredicate predicateWithFormat:@"SELF MATCHES %@", regex];    
    
if ([predicate evaluateWithObject:aString]) {    
} 
NSError* error = NULL;    
NSRegularExpression* regex = [NSRegularExpression regularExpressionWithPattern:@"(encoding=\")[^\"]+(\")"    
                                                                            options:0    
                                                                            error:&error];    
NSString* sample = @"<xml encoding=\"abc\"></xml><xml encoding=\"def\"></xml><xml encoding=\"ttt\"></xml>";    
NSLog(@"Start:%@",sample);    
NSString* result = [regex stringByReplacingMatchesInString:sample    
                                                      options:0    
                                                       range:NSMakeRange(0, sample.length)    
                                                      withTemplate:@"$1utf-8$2"];    
NSLog(@"Result:%@", result); 
//组装一个字符串,需要把里面的网址解析出来    
NSString *urlString=@"<meta/><link/><title>1Q84 BOOK1</title></head><body>";    
    
//NSRegularExpression类里面调用表达的方法需要传递一个NSError的参数。下面定义一个      
NSError *error;    
    
//http+:[^\\s]* 这个表达式是检测一个网址的。(?<=title\>).*(?=</title)截取html文章中的<title></title>中内文字的正则表达式    
NSRegularExpression *regex = [NSRegularExpression regularExpressionWithPattern:@"(?<=title\\>).*(?=</title)" options:0 error:&error];    
    
if (regex != nil) {    
    NSTextCheckingResult *firstMatch=[regex firstMatchInString:urlString options:0 range:NSMakeRange(0, [urlString length])];    
        
    if (firstMatch) {    
        NSRange resultRange = [firstMatch rangeAtIndex:0];    
            
        //从urlString当中截取数据    
        NSString *result=[urlString substringWithRange:resultRange];    
        //输出结果    
        NSLog(@"->%@<-",result);    
    }    
        
}
 
//日期在十天之内:  
NSDate *endDate = [[NSDate date] retain];  
NSTimeInterval timeInterval= [endDate timeIntervalSinceReferenceDate];  
timeInterval -=3600*24*10;  
NSDate *beginDate = [[NSDate dateWithTimeIntervalSinceReferenceDate:timeInterval] retain];  
//对coredata进行筛选(假设有fetchRequest)  
NSPredicate *predicate_date =  
[NSPredicate predicateWithFormat:@"date >= %@ AND date <= %@", beginDate,endDate];  
      
[fetchRequest setPredicate:predicate_date];  
//释放retained的对象  
[endDate release];  
[beginDate release]; 
额外补充

predicateWithFormat:
NSPredicate *predicate;
predicate = [NSPredicate predicateWithFormat:@"name == 'Herbie'"];
注意:如果谓词串中的文本块未被引用,则被看做是键路径,即需要用引号表明是字符串,单引号,双引号均可.键路径可以在后台包含许多强大的功能
计算谓词:
BOOL match = [predicate evaluateWithObject:car];
让谓词通过某个对象来计算自己的值,给出BOOL值

filteredArrayUsingPredicate:是NSArray数组的一种类别方法,循环过滤数组中的内容,将值为YES的对象累积到结果数组中返回
iphone编程应该密切注意谓词使用带来的性能问题

%d和%@等插入数值和字符串,%K表示key
还可以引入变量名,用,类似环境变量,如:@"name ==NAME",再用predicateWithSubstitutionVariables调用来构造新的谓词(键/值字典),其中键是变量名,值是要插入的内容,注意这种情况下不能把变量当成键路径,只能用作值

==等于
>:大于
>=和=>:大于或等于
<:小于
<=和=<:小于或等于
!=和<>:不等于
括号和逻辑运算AND、OR、NOT或者C样式的等效表达式&&、||、!
注意:不等号适用于数字和字符串

BETWEEN和IN后加某个数组,可以用{50,200},也可以用%@格式说明符插入自己的对象,也可以用变量

self就表示对象本身

BEGINSWITH

ENDSWITH
CONTAINS
[c],[d],[cd],后缀表示不区分大小写,不区分发音符号,两这个都不区分

类似SQL的LIKES
LIKE,与通配符“*”表示任意多和“?”表示一个结合使用
LIKE也接受[cd]符号
MATCHES可以使用正则表达式

Car *makeCar (NSString *name, NSString *make, NSString *model,  
              int modelYear, int numberOfDoors, float mileage,  
              int horsepower) {  
    Car *car = [[[Car alloc] init] autorelease];  
      
    car.name = name;  
    car.make = make;  
    car.model = model;  
    car.modelYear = modelYear;  
    car.numberOfDoors = numberOfDoors;  
    car.mileage = mileage;  
      
    Slant6 *engine = [[[Slant6 alloc] init] autorelease];  
    [engine setValue: [NSNumber numberWithInt: horsepower]  
              forKey: @"horsepower"];  
    car.engine = engine;  
      
      
    // Make some tires.  
    // int i;  
    for (int i = 0; i < 4; i++) {  
        Tire * tire= [[[Tire alloc] init] autorelease];  
        [car setTire: tire  atIndex: i];  
    }  
      
    return (car);  
      
} // makeCar  
  
  
int main (int argc, const char * argv[])  
{  
    NSAutoreleasePool *pool;  
    pool = [[NSAutoreleasePool alloc] init];  
      
    Garage *garage = [[Garage alloc] init];  
    garage.name = @"Joe's Garage";  
      
    Car *car;  
    car = makeCar (@"Herbie", @"Honda", @"CRX", 1984, 2, 34000, 58);  
    [garage addCar: car];  
  
    NSPredicate *predicate;  
    predicate = [NSPredicate predicateWithFormat: @"name == 'Herbie'"];  
    BOOL match = [predicate evaluateWithObject: car];  
    NSLog (@"%s", (match) ? "YES" : "NO");  
      
    predicate = [NSPredicate predicateWithFormat: @"engine.horsepower > 150"];  
    match = [predicate evaluateWithObject: car];  
    NSLog (@"%s", (match) ? "YES" : "NO");  
      
    predicate = [NSPredicate predicateWithFormat: @"name == %@", @"Herbie"];  
    match = [predicate evaluateWithObject: car];  
    NSLog (@"%s", (match) ? "YES" : "NO");  
      
    predicate = [NSPredicate predicateWithFormat: @"%K == %@", @"name", @"Herbie"];  
    match = [predicate evaluateWithObject: car];  
    NSLog (@"%s", (match) ? "YES" : "NO");  
      
    NSPredicate *predicateTemplate = [NSPredicate predicateWithFormat:@"name == $NAME"];  
    NSDictionary *varDict;  
    varDict = [NSDictionary dictionaryWithObjectsAndKeys:  
               @"Herbie", @"NAME", nil];  
    predicate = [predicateTemplate predicateWithSubstitutionVariables: varDict];  
    NSLog(@"SNORGLE: %@", predicate);  
    match = [predicate evaluateWithObject: car];  
    NSLog (@"%s", (match) ? "YES" : "NO");  
      
      
    car = makeCar (@"Badger", @"Acura", @"Integra", 1987, 5, 217036.7, 130);  
    [garage addCar: car];  
      
    car = makeCar (@"Elvis", @"Acura", @"Legend", 1989, 4, 28123.4, 151);  
    [garage addCar: car];  
      
    car = makeCar (@"Phoenix", @"Pontiac", @"Firebird", 1969, 2, 85128.3, 345);  
    [garage addCar: car];  
      
    car = makeCar (@"Streaker", @"Pontiac", @"Silver Streak", 1950, 2, 39100.0, 36);  
    [garage addCar: car];  
      
    car = makeCar (@"Judge", @"Pontiac", @"GTO", 1969, 2, 45132.2, 370);  
    [garage addCar: car];  
      
    car = makeCar (@"Paper Car", @"Plymouth", @"Valiant", 1965, 2, 76800, 105);  
    [garage addCar: car];  
      
    predicate = [NSPredicate predicateWithFormat: @"engine.horsepower > 150"];  
    NSArray *cars = [garage cars];  
    for (Car *car in [garage cars]) {  
        if ([predicate evaluateWithObject: car]) {  
            NSLog (@"%@", car.name);  
        }  
    }  
  
    predicate = [NSPredicate predicateWithFormat: @"engine.horsepower > 150"];  
    NSArray *results;  
    results = [cars filteredArrayUsingPredicate: predicate];  
    NSLog (@"%@", results);  
      
    NSArray *names;  
    names = [results valueForKey:@"name"];  
    NSLog (@"%@", names);  
      
    NSMutableArray *carsCopy = [cars mutableCopy];  
    [carsCopy filterUsingPredicate: predicate];  
    NSLog (@"%@", carsCopy);  
      
    predicate = [NSPredicate predicateWithFormat: @"engine.horsepower > %d", 50];  
    results = [cars filteredArrayUsingPredicate: predicate];  
    NSLog (@"%@", results);  
      
    predicateTemplate = [NSPredicate predicateWithFormat: @"engine.horsepower > $POWER"];  
    varDict = [NSDictionary dictionaryWithObjectsAndKeys:  
               [NSNumber numberWithInt: 150], @"POWER", nil];  
    predicate = [predicateTemplate predicateWithSubstitutionVariables: varDict];  
    results = [cars filteredArrayUsingPredicate: predicate];  
    NSLog (@"%@", results);  
      
    predicate = [NSPredicate predicateWithFormat:  
                 @"(engine.horsepower > 50) AND (engine.horsepower < 200)"];  
    results = [cars filteredArrayUsingPredicate: predicate];  
    NSLog (@"oop %@", results);  
      
    predicate = [NSPredicate predicateWithFormat: @"name < 'Newton'"];  
    results = [cars filteredArrayUsingPredicate: predicate];  
    NSLog (@"%@", [results valueForKey: @"name"]);  
      
    predicate = [NSPredicate predicateWithFormat:  
                 @"engine.horsepower BETWEEN { 50, 200 }"];  
    results = [cars filteredArrayUsingPredicate: predicate];  
    NSLog (@"%@", results);  
      
    NSArray *betweens = [NSArray arrayWithObjects:  
                         [NSNumber numberWithInt: 50], [NSNumber numberWithInt: 200], nil];  
    predicate = [NSPredicate predicateWithFormat: @"engine.horsepower BETWEEN %@", betweens];  
    results = [cars filteredArrayUsingPredicate: predicate];  
    NSLog (@"%@", results);  
  
    predicateTemplate = [NSPredicate predicateWithFormat: @"engine.horsepower BETWEEN $POWERS"];  
    varDict = [NSDictionary dictionaryWithObjectsAndKeys: betweens, @"POWERS", nil];  
    predicate = [predicateTemplate predicateWithSubstitutionVariables: varDict];  
    results = [cars filteredArrayUsingPredicate: predicate];  
    NSLog (@"%@", results);  
      
    predicate = [NSPredicate predicateWithFormat: @"name IN { 'Herbie', 'Snugs', 'Badger', 'Flap' }"];  
    results = [cars filteredArrayUsingPredicate: predicate];  
    NSLog (@"%@", [results valueForKey: @"name"]);  
  
    predicate = [NSPredicate predicateWithFormat: @"SELF.name IN { 'Herbie', 'Snugs', 'Badger', 'Flap' }"];  
    results = [cars filteredArrayUsingPredicate: predicate];  
    NSLog (@"%@", [results valueForKey: @"name"]);  
      
    names = [cars valueForKey: @"name"];  
    predicate = [NSPredicate predicateWithFormat: @"SELF IN { 'Herbie', 'Snugs', 'Badger', 'Flap' }"];  
    results = [names filteredArrayUsingPredicate: predicate];  
    NSLog (@"%@", results);  
      
    predicate = [NSPredicate predicateWithFormat: @"name BEGINSWITH 'Bad'"];  
    results = [cars filteredArrayUsingPredicate: predicate];  
    NSLog (@"%@", results);  
      
    predicate = [NSPredicate predicateWithFormat: @"name BEGINSWITH 'HERB'"];  
    results = [cars filteredArrayUsingPredicate: predicate];  
    NSLog (@"%@", results);  
      
    predicate = [NSPredicate predicateWithFormat: @"name BEGINSWITH[cd] 'HERB'"];  
    results = [cars filteredArrayUsingPredicate: predicate];  
    NSLog (@"%@", results);  
      
    predicate = [NSPredicate predicateWithFormat: @"name LIKE[cd] '*er*'"];  
    results = [cars filteredArrayUsingPredicate: predicate];  
    NSLog (@"%@", results);  
      
    predicate = [NSPredicate predicateWithFormat: @"name LIKE[cd] '???er*'"];  
    results = [cars filteredArrayUsingPredicate: predicate];  
    NSLog (@"%@", results);  
      
    NSArray *names1 = [NSArray arrayWithObjects: @"Herbie", @"Badger", @"Judge", @"Elvis", nil];  
    NSArray *names2 = [NSArray arrayWithObjects: @"Judge", @"Paper Car", @"Badger", @"Phoenix", nil];  
  
    predicate = [NSPredicate predicateWithFormat: @"SELF IN %@", names1];  
    results = [names2 filteredArrayUsingPredicate: predicate];  
    NSLog (@"%@", predicate);  
    NSLog (@"%@", results);  
      
          
    return 0;  
  
      
      
    predicate = [NSPredicate predicateWithFormat: @"modelYear > 1970"];  
    results = [cars filteredArrayUsingPredicate: predicate];  
    NSLog (@"%@", results);  
      
    predicate = [NSPredicate predicateWithFormat: @"name contains[cd] 'er'"];  
    results = [cars filteredArrayUsingPredicate: predicate];  
    NSLog (@"%@", results);  
  
    predicate = [NSPredicate predicateWithFormat: @"name beginswith 'B'"];  
    results = [cars filteredArrayUsingPredicate: predicate];  
    NSLog (@"%@", results);  
      
    predicate = [NSPredicate predicateWithFormat: @"%K beginswith %@",  
                 @"name", @"B"];  
    results = [cars filteredArrayUsingPredicate: predicate];  
    NSLog (@"with args : %@", results);  
      
    predicateTemplate = [NSPredicate predicateWithFormat: @"name beginswith $NAME"];  
    NSDictionary *dict = [NSDictionary   
                          dictionaryWithObjectsAndKeys: @"Bad", @"NAME", nil];  
    predicate = [predicateTemplate predicateWithSubstitutionVariables:dict];  
    NSLog (@"SNORGLE: %@", predicate);  
      
    predicate = [NSPredicate predicateWithFormat: @"name in { 'Badger', 'Judge', 'Elvis' }"];  
    results = [cars filteredArrayUsingPredicate: predicate];  
    NSLog (@"%@", results);  
      
    predicateTemplate = [NSPredicate predicateWithFormat: @"name in $NAME_LIST"];  
    names = [NSArray arrayWithObjects:@"Badger", @"Judge", @"Elvis", nil];  
    dict = [NSDictionary   
                          dictionaryWithObjectsAndKeys: names, @"NAME_LIST", nil];  
    predicate = [predicateTemplate predicateWithSubstitutionVariables:dict];  
    results = [cars filteredArrayUsingPredicate: predicate];  
    NSLog (@"%@", results);  
      
    predicateTemplate = [NSPredicate predicateWithFormat: @"%K in $NAME_LIST", @"name"];  
    dict = [NSDictionary   
    dictionaryWithObjectsAndKeys: names, @"NAME_LIST", nil];  
    predicate = [predicateTemplate predicateWithSubstitutionVariables:dict];  
    results = [cars filteredArrayUsingPredicate: predicate];  
    NSLog (@"%@", results);  
    NSLog (@"xSNORGLE: %@", predicate);  
      
    // SELF is optional here.  
    predicate = [NSPredicate predicateWithFormat:@"SELF.name in { 'Badger', 'Judge', 'Elvis' }"];  
      
    for (Car *car in cars) {  
        if ([predicate evaluateWithObject: car]) {  
            NSLog (@"SNORK : %@ matches", car.name);  
        }  
    }  
      
      
#if 0  
    predicate = [NSPredicate predicateWithFormat: @"ANY engine.horsepower > 200"];  
    results = [cars filteredArrayUsingPredicate: predicate];  
    NSLog (@"SNORGLE: %@", predicate);  
#endif  
      
    predicate = [NSPredicate predicateWithFormat: @"engine.horsepower > 200"];  
    results = [cars filteredArrayUsingPredicate: predicate];  
    NSLog (@"%@", results);  
      
    predicate = [NSPredicate predicateWithFormat: @"tires.@sum.pressure > 10"];  
    results = [cars filteredArrayUsingPredicate: predicate];  
    NSLog (@"%@", results);  
  
#if 0  
    predicate = [NSPredicate predicateWithFormat: @"ALL engine.horsepower > 30"];  
    results = [cars filteredArrayUsingPredicate: predicate];  
    NSLog (@"%@", results);  
#endif  
      
      
    [garage release];  
      
    [pool release];  
      
    return (0);  
      
}

判断字符串首字母是否为字母。
Objective-c代码
NSString *regex = @"[A-Za-z]+";
NSPredicate *predicate = [NSPredicate predicateWithFormat:@"SELF MATCHES %@", regex];
if ([predicate evaluateWithObject:aString]) {
}

上一篇下一篇

猜你喜欢

热点阅读