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

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

  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进行过滤

  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)判断字符串首字母是否为字母:

  1. NSString *regex = @"[A-Za-z]+";
  2. NSPredicate *predicate = [NSPredicate predicateWithFormat:@"SELF MATCHES %@", regex];
  3. if ([predicate evaluateWithObject:aString]) {
  4. }

(3)字符串替换:

  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)截取字符串:

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

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

  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. NSPredicate *regextestmobile = [NSPredicate predicateWithFormat:@"SELF MATCHES %@", MOBILE];
  33. NSPredicate *regextestcm = [NSPredicate predicateWithFormat:@"SELF MATCHES %@", CM];
  34. NSPredicate *regextestcu = [NSPredicate predicateWithFormat:@"SELF MATCHES %@", CU];
  35. NSPredicate *regextestct = [NSPredicate predicateWithFormat:@"SELF MATCHES %@", CT];
  36. if (([regextestmobile evaluateWithObject:mobileNum] == YES)
  37. || ([regextestcm evaluateWithObject:mobileNum] == YES)
  38. || ([regextestct evaluateWithObject:mobileNum] == YES)
  39. || ([regextestcu evaluateWithObject:mobileNum] == YES))
  40. {
  41. if([regextestcm evaluateWithObject:mobileNum] == YES) {
  42. NSLog(@"China Mobile");
  43. } else if([regextestct evaluateWithObject:mobileNum] == YES) {
  44. NSLog(@"China Telecom");
  45. } else if ([regextestcu evaluateWithObject:mobileNum] == YES) {
  46. NSLog(@"China Unicom");
  47. } else {
  48. NSLog(@"Unknow");
  49. }
  50. return YES;
  51. }
  52. else
  53. {
  54. return NO;
  55. }
  56. }

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

  1. //是否是有效的正则表达式
  2. +(BOOL)isValidateRegularExpression:(NSString *)strDestination byExpression:(NSString *)strExpression
  3. {
  4. NSPredicate *predicate = [NSPredicatepredicateWithFormat:@"SELF MATCHES %@", strExpression];
  5. return [predicate evaluateWithObject:strDestination];
  6. }
  7. //验证email
  8. +(BOOL)isValidateEmail:(NSString *)email {
  9. NSString *strRegex = @"[A-Z0-9a-z._%+-]+@[A-Za-z0-9.-]+\\.[A-Za-z]{1,5}";
  10. BOOL rt = [CommonTools isValidateRegularExpression:email byExpression:strRegex];
  11. return rt;
  12. }
  13. //验证电话号码
  14. +(BOOL)isValidateTelNumber:(NSString *)number {
  15. NSString *strRegex = @"[0-9]{1,20}";
  16. BOOL rt = [CommonTools isValidateRegularExpression:number byExpression:strRegex];
  17. return rt;
  18. }

(7)NSDate进行筛选

    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. [fetchRequest setPredicate:predicate_date];
    10. //释放retained的对象
    11. [endDate release];
    12. [beginDate release];

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

  1. Swift中的map 和 flatMap 原理及用法

    之前对这两个概念有点糊,今天正好遇到一个相关需求,才深入了解了下. 需求如下: 大概就是对一个数组的model,重构成一个新model,返回得到一个新数组 用map很容易实现,不过后来我需要对其中进行 ...

  2. hibernate中java类的成员变量类型如何映射到SQL中的数据类型变化

    hibernate映射文件??.hbm.xml配置映射元素详解--Hibernate映射类型 在从Hibernate的java的成员类型映射到SQL中的数据类型,其内映射方式它满足,SQL可以自己调制 ...

  3. C#EF中,使用类似于SQL中的% 模糊查询

    最近在做项目的时候需要使用到模糊查询,但是后台使用EF写的 而不是ADO或者是Dapper,如果是这样的话,我们就可以使用Sql语句直接进行模糊查询 现在我们需要在LINQ中使用类似于模糊查询 在EF ...

  4. C# ACCESS 向含有自动编码字段表中添加记录提示“查询值的数目与目标字段中的数目不同”

    引发错误的SQL语句如下: sqlStr = "insert into tb_ReportLog values('" + DevSite + "','" + D ...

  5. js中两个感叹号的原理与用法分析

    在javascript中有时会看到有两个!!的用法 var foo; alert(!foo);//undifined情况下,一个感叹号返回的是true; alert(!goo);//null情况下,一 ...

  6. Hibernate中createCriteria即QBC查询的详细用法 .Hibernate中createCriteria即QBC查询的详细用法 .

    现在假设有一个Student类,内有id,name,age属性String hql = "from Student s";按照以前的做法,我们通常是Query query = se ...

  7. js中两个感叹号的原理与用法分析(转载记录没找到原帖)

    var foo; alert(!foo);//undifined情况下,一个感叹号返回的是true; alert(!goo);//null情况下,一个感叹号返回的也是true; var o={flag ...

  8. Hibernate中createCriteria即QBC查询的详细用法

    现在假设有一个Student类,内有id,name,age属性String hql = "from Student s";按照以前的做法,我们通常是Query query = se ...

  9. C# Lamda中类似于SQL 中的 In 功能

    首先,在程序中接受一个数组 例如:int[] s=[1,2,3]; 在Lamda表达式中使用如下: db.userinfo.where(u=>s.Contains(u.id)); 等同于sql语 ...

随机推荐

  1. spoj 375 树链剖分 模板

    QTREE - Query on a tree #tree You are given a tree (an acyclic undirected connected graph) with N no ...

  2. 在VC6/VC2005下使程序直接具有XP风格(XP Style):

    原文 首先将以下文本保存为XpStyle.mainfest(后经实践,文件名和后缀是什么都无所谓) <?xml version="1.0" encoding="UT ...

  3. unity还原three之旋转

    http://www.360doc.com/content/16/0829/14/12282510_586760119.shtml unity使用左手坐标系,另外在做旋转的时候必须弄清楚旋转坐标轴和旋 ...

  4. Java基础-Collection子接口之Set接口

    Java基础-Collection子接口之Set接口 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 学习Collection接口时,记得Collection中可以存放重复元素,也可 ...

  5. 2017 清北济南考前刷题Day 5 afternoon

    期望得分:100+100+30=230 实际得分:0+0+0=30 T1 直接模拟 #include<cstdio> #include<iostream> using name ...

  6. 接口测试Case之面向页面对象编写及规范

    一.什么是页面对象化 主要提倡的思想是:万物皆对象,即把一个Page看成一个对象,来进行接口自动化Case的编写,不要闲扯,直接讲怎么个操作法呢? 二.有什么优势? 2.1 Case层次清晰,便于管理 ...

  7. crontab定时任务_net

    2017年2月25日, 星期六 crontab定时任务 19. crontab 定时任务 通过crontab 命令,我们可以在固定的间隔时间执行指定的系统指令或 shell script脚本.时间间隔 ...

  8. 【mybatis笔记】 resultType与resultMap的区别

    序言: 昨天做一个项目,看到很多刚开始用mybatis的同事对于resultType和resultMap的理解与使用含糊不清,这里我试图用最好理解的说法写一写,欢迎大家勘误. 两者异同: 相同点:re ...

  9. JDK各版本新特性总结

    序言 北风潜入悄无声,未品浓秋已立冬. JDK1.1--1996 JDK1.2--1998 JDK1.3--2000 JDK1.4--2002 JDK5.0--2004 JDK6.0--2006 JD ...

  10. CentOS 7快速入门系列教程(一)

    基本命令 ls 列举当前目录下的所有文件夹 ls -l 查看文件还是文件夹   d表示文件夹   -表示文件 ls --help man ls 询问命令 man 3 malloc 查看函数 cd 跳转 ...