NSPredicate用法总结(Cocoa框架中的NSPredicate用于查询,原理和用法都类似于SQL中的where,作用相当于数据库的过滤取)

简介: 简述:Cocoa框架中的NSPredicate用于查询,原理和用法都类似于SQL中的where,作用相当于数据库的过滤取。 定义(最常用到的方法):   [objc] view plaincopy   NSPredicate *ca = [NSPredicate predicateWithFormat:(NSString *), .

简述:Cocoa框架中的NSPredicate用于查询,原理和用法都类似于SQL中的where,作用相当于数据库的过滤取。

定义(最常用到的方法):

 

[objc]  view plain copy 在CODE上查看代码片 派生到我的代码片
 
  1. NSPredicate *ca = [NSPredicate predicateWithFormat:(NSString *), ...];   

Format:
(1)比较运算符>,<,==,>=,<=,!=
可用于数值及字符串
例:@"number > 100"


(2)范围运算符:IN、BETWEEN
例:@"number BETWEEN {1,5}"
      @"address IN {'shanghai','beijing'}"


(3)字符串本身:SELF 
例:@“SELF == ‘APPLE’"


(4)字符串相关:BEGINSWITH、ENDSWITH、CONTAINS
例:@"name CONTAIN[cd] 'ang'"   //包含某个字符串
       @"name BEGINSWITH[c] 'sh'"     //以某个字符串开头
       @"name ENDSWITH[d] 'ang'"      //以某个字符串结束
        注:[c]不区分大小写[d]不区分发音符号即没有重音符号[cd]既不区分大小写,也不区分发音符号。


(5)通配符:LIKE
例:@"name LIKE[cd] '*er*'"    //*代表通配符,Like也接受[cd].
       @"name LIKE[cd] '???er*'"

 

 


(6)正则表达式:MATCHES
例:NSString *regex = @"^A.+e$";   //以A开头,e结尾
      @"name MATCHES %@",regex

 

实际应用:
(1)对NSArray进行过滤

[objc]  view plain copy 在CODE上查看代码片 派生到我的代码片
 
  1. NSArray *array = [[NSArray alloc]initWithObjects:@"beijing",@"shanghai",@"guangzou",@"wuhan", nil nil];      
  2. NSString *string = @"ang";      
  3. NSPredicate *pred = [NSPredicate predicateWithFormat:@"SELF CONTAINS %@",string];      
  4. NSLog(@"%@",[array filteredArrayUsingPredicate:pred]);    


(2)判断字符串首字母是否为字母:

 

[objc]  view plain copy 在CODE上查看代码片 派生到我的代码片
 
  1. NSString *regex = @"[A-Za-z]+";      
  2. NSPredicate *predicate = [NSPredicate predicateWithFormat:@"SELF MATCHES %@", regex];      
  3.       
  4. if ([predicate evaluateWithObject:aString]) {      
  5. }    


(3)字符串替换:

 

 

[objc]  view plain copy 在CODE上查看代码片 派生到我的代码片
 
  1. NSError* error = NULL;      
  2. NSRegularExpression* regex = [NSRegularExpression regularExpressionWithPattern:@"(encoding=\")[^\"]+(\")"      
  3.                                                                             options:0      
  4.                                                                             error:&error];      
  5. NSString* sample = @"<xml encoding=\"abc\"></xml><xml encoding=\"def\"></xml><xml encoding=\"ttt\"></xml>";      
  6. NSLog(@"Start:%@",sample);      
  7. NSString* result = [regex stringByReplacingMatchesInString:sample      
  8.                                                       options:0      
  9.                                                        range:NSMakeRange(0, sample.length)      
  10.                                                       withTemplate:@"$1utf-8$2"];      
  11. NSLog(@"Result:%@", result);  


(4)截取字符串:

 

 

[objc]  view plain copy 在CODE上查看代码片 派生到我的代码片
 
  1. //组装一个字符串,需要把里面的网址解析出来      
  2. NSString *urlString=@"<meta/><link/><title>1Q84 BOOK1</title></head><body>";      
  3.       
  4. //NSRegularExpression类里面调用表达的方法需要传递一个NSError的参数。下面定义一个        
  5. NSError *error;      
  6.       
  7. //http+:[^\\s]* 这个表达式是检测一个网址的。(?<=title\>).*(?=</title)截取html文章中的<title></title>中内文字的正则表达式      
  8. NSRegularExpression *regex = [NSRegularExpression regularExpressionWithPattern:@"(?<=title\\>).*(?=</title)" options:0 error:&error];      
  9.       
  10. if (regex != nil) {      
  11.     NSTextCheckingResult *firstMatch=[regex firstMatchInString:urlString options:0 range:NSMakeRange(0, [urlString length])];      
  12.           
  13.     if (firstMatch) {      
  14.         NSRange resultRange = [firstMatch rangeAtIndex:0];      
  15.               
  16.         //从urlString当中截取数据      
  17.         NSString *result=[urlString substringWithRange:resultRange];      
  18.         //输出结果      
  19.         NSLog(@"->%@<-",result);      
  20.     }      
  21.           
  22. }      


(5)判断手机号码,电话号码函数 

 

 

[objc]  view plain copy 在CODE上查看代码片 派生到我的代码片
 
  1. // 正则判断手机号码地址格式    
  2. - (BOOL)isMobileNumber:(NSString *)mobileNum    
  3. {    
  4.        /**  
  5.         * 手机号码  
  6.         * 移动:134[0-8],135,136,137,138,139,150,151,157,158,159,182,187,188  
  7.         * 联通:130,131,132,152,155,156,185,186  
  8.         * 电信:133,1349,153,180,189  
  9.         */    
  10.        NSString * MOBILE = @"^1(3[0-9]|5[0-35-9]|8[025-9])\\d{8}$";    
  11.        /**  
  12.         * 中国移动:China Mobile  
  13.         * 134[0-8],135,136,137,138,139,150,151,157,158,159,182,187,188  
  14.         */    
  15.        NSString * CM = @"^1(34[0-8]|(3[5-9]|5[017-9]|8[278])\\d)\\d{7}$";    
  16.        /**  
  17.         * 中国联通:China Unicom  
  18.         * 130,131,132,152,155,156,185,186  
  19.         */    
  20.        NSString * CU = @"^1(3[0-2]|5[256]|8[56])\\d{8}$";    
  21.        /**  
  22.         * 中国电信:China Telecom  
  23.         * 133,1349,153,180,189  
  24.         */    
  25.        NSString * CT = @"^1((33|53|8[09])[0-9]|349)\\d{7}$";    
  26.        /**  
  27.         * 大陆地区固话及小灵通  
  28.         * 区号:010,020,021,022,023,024,025,027,028,029  
  29.         * 号码:七位或八位  
  30.         */    
  31.       // NSString * PHS = @"^0(10|2[0-5789]|\\d{3})\\d{7,8}$";    
  32.         
  33.      NSPredicate *regextestmobile = [NSPredicate predicateWithFormat:@"SELF MATCHES %@", MOBILE];    
  34.      NSPredicate *regextestcm = [NSPredicate predicateWithFormat:@"SELF MATCHES %@", CM];    
  35.      NSPredicate *regextestcu = [NSPredicate predicateWithFormat:@"SELF MATCHES %@", CU];    
  36.      NSPredicate *regextestct = [NSPredicate predicateWithFormat:@"SELF MATCHES %@", CT];    
  37.         
  38.     if (([regextestmobile evaluateWithObject:mobileNum] == YES)    
  39.     || ([regextestcm evaluateWithObject:mobileNum] == YES)    
  40.     || ([regextestct evaluateWithObject:mobileNum] == YES)    
  41.     || ([regextestcu evaluateWithObject:mobileNum] == YES))    
  42.     {    
  43.         if([regextestcm evaluateWithObject:mobileNum] == YES) {    
  44.           NSLog(@"China Mobile");    
  45.         } else if([regextestct evaluateWithObject:mobileNum] == YES) {    
  46.           NSLog(@"China Telecom");    
  47.         } else if ([regextestcu evaluateWithObject:mobileNum] == YES) {    
  48.           NSLog(@"China Unicom");    
  49.         } else {    
  50.           NSLog(@"Unknow");    
  51.         }    
  52.             
  53.         return YES;    
  54.     }    
  55.     else     
  56.     {    
  57.         return NO;    
  58.     }    
  59. }   


(6)邮箱验证、电话号码验证:

 

 

[objc]  view plain copy 在CODE上查看代码片 派生到我的代码片
 
  1. //是否是有效的正则表达式    
  2.     
  3. +(BOOL)isValidateRegularExpression:(NSString *)strDestination byExpression:(NSString *)strExpression    
  4.     
  5. {    
  6.     
  7.    NSPredicate *predicate = [NSPredicatepredicateWithFormat:@"SELF MATCHES %@", strExpression];      
  8.     
  9.    return [predicate evaluateWithObject:strDestination];    
  10.     
  11. }    
  12.     
  13. //验证email    
  14. +(BOOL)isValidateEmail:(NSString *)email {    
  15.     
  16.    NSString *strRegex = @"[A-Z0-9a-z._%+-]+@[A-Za-z0-9.-]+\\.[A-Za-z]{1,5}";    
  17.     
  18.    BOOL rt = [CommonTools isValidateRegularExpression:email byExpression:strRegex];    
  19.     
  20.    return rt;    
  21.     
  22. }    
  23.     
  24. //验证电话号码    
  25. +(BOOL)isValidateTelNumber:(NSString *)number {    
  26.     
  27.    NSString *strRegex = @"[0-9]{1,20}";    
  28.     
  29.    BOOL rt = [CommonTools isValidateRegularExpression:number byExpression:strRegex];    
  30.     
  31.    return rt;    
  32.     
  33. }   


(7)NSDate进行筛选

 

 

[objc]  view plain copy 在CODE上查看代码片 派生到我的代码片
 
    1. //日期在十天之内:    
    2. NSDate *endDate = [[NSDate date] retain];    
    3. NSTimeInterval timeInterval= [endDate timeIntervalSinceReferenceDate];    
    4. timeInterval -=3600*24*10;    
    5. NSDate *beginDate = [[NSDate dateWithTimeIntervalSinceReferenceDate:timeInterval] retain];    
    6. //对coredata进行筛选(假设有fetchRequest)    
    7. NSPredicate *predicate_date =    
    8. [NSPredicate predicateWithFormat:@"date >= %@ AND date <= %@", beginDate,endDate];    
    9.         
    10. [fetchRequest setPredicate:predicate_date];    
    11. //释放retained的对象    
    12. [endDate release];    
    13. [beginDate release];   
如何联系我:【万里虎】www.bravetiger.cn 【QQ】3396726884 (咨询问题100元起,帮助解决问题500元起) 【博客】http://www.cnblogs.com/kenshinobiy/
目录
相关文章
|
14天前
|
SQL 监控 安全
Flask 框架防止 SQL 注入攻击的方法
通过综合运用以上多种措施,Flask 框架可以有效地降低 SQL 注入攻击的风险,保障应用的安全稳定运行。同时,持续的安全评估和改进也是确保应用长期安全的重要环节。
127 71
|
9天前
|
SQL 存储 人工智能
Vanna:开源 AI 检索生成框架,自动生成精确的 SQL 查询
Vanna 是一个开源的 Python RAG(Retrieval-Augmented Generation)框架,能够基于大型语言模型(LLMs)为数据库生成精确的 SQL 查询。Vanna 支持多种 LLMs、向量数据库和 SQL 数据库,提供高准确性查询,同时确保数据库内容安全私密,不外泄。
64 7
Vanna:开源 AI 检索生成框架,自动生成精确的 SQL 查询
|
9天前
|
SQL 关系型数据库 MySQL
MySQL导入.sql文件后数据库乱码问题
本文分析了导入.sql文件后数据库备注出现乱码的原因,包括字符集不匹配、备注内容编码问题及MySQL版本或配置问题,并提供了详细的解决步骤,如检查和统一字符集设置、修改客户端连接方式、检查MySQL配置等,确保导入过程顺利。
|
8天前
|
SQL 监控 安全
SQL Servers审核提高数据库安全性
SQL Server审核是一种追踪和审查SQL Server上所有活动的机制,旨在检测潜在威胁和漏洞,监控服务器设置的更改。审核日志记录安全问题和数据泄露的详细信息,帮助管理员追踪数据库中的特定活动,确保数据安全和合规性。SQL Server审核分为服务器级和数据库级,涵盖登录、配置变更和数据操作等事件。审核工具如EventLog Analyzer提供实时监控和即时告警,帮助快速响应安全事件。
|
13天前
|
SQL 安全 Java
除了Flask框架,还有哪些框架能防止SQL注入攻击?
这些框架都在安全方面有着较好的表现,通过它们的内置机制和安全特性,可以有效地降低 SQL 注入攻击的风险。然而,无论使用哪个框架,开发者都需要具备良好的安全意识,正确配置和使用框架提供的安全功能,以确保应用的安全可靠。同时,持续关注安全更新和漏洞修复也是非常重要的。
34 7
|
11天前
|
SQL 存储 关系型数据库
MySQL进阶突击系列(01)一条简单SQL搞懂MySQL架构原理 | 含实用命令参数集
本文从MySQL的架构原理出发,详细介绍其SQL查询的全过程,涵盖客户端发起SQL查询、服务端SQL接口、解析器、优化器、存储引擎及日志数据等内容。同时提供了MySQL常用的管理命令参数集,帮助读者深入了解MySQL的技术细节和优化方法。
|
17天前
|
SQL Java
使用java在未知表字段情况下通过sql查询信息
使用java在未知表字段情况下通过sql查询信息
33 8
|
19天前
|
SQL 自然语言处理 数据库
XiYan-SQL:一种多生成器集成的Text-to-SQL框架
XiYan-SQL 是一种创新的多生成器集成Text-to-SQL框架,通过M-Schema增强模型对数据库结构的理解,结合ICL与SFT方法提升SQL生成质量和多样性,经实验证明在多个数据集上表现优异,特别是在Spider和SQL-Eval上取得了领先成绩。
|
23天前
|
SQL 安全 PHP
PHP开发中防止SQL注入的方法,包括使用参数化查询、对用户输入进行过滤和验证、使用安全的框架和库等,旨在帮助开发者有效应对SQL注入这一常见安全威胁,保障应用安全
本文深入探讨了PHP开发中防止SQL注入的方法,包括使用参数化查询、对用户输入进行过滤和验证、使用安全的框架和库等,旨在帮助开发者有效应对SQL注入这一常见安全威胁,保障应用安全。
43 4
|
18天前
|
SQL Java 数据库连接
canal-starter 监听解析 storeValue 不一样,同样的sql 一个在mybatis执行 一个在数据库操作,导致解析不出正确对象
canal-starter 监听解析 storeValue 不一样,同样的sql 一个在mybatis执行 一个在数据库操作,导致解析不出正确对象