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

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

[cpp] view plaincopy
  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进行过滤

[cpp] view plaincopy
  1. NSArray *array = [[NSArray alloc]initWithObjects:@"beijing",@"shanghai",@"guangzou",@"wuhan", nil];
  2. NSString *string = @"ang";
  3. NSPredicate *pred = [NSPredicate predicateWithFormat:@"SELF CONTAINS %@",string];
  4. NSLog(@"%@",[array filteredArrayUsingPredicate:pred]);

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

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

(3)字符串替换:

[cpp] view plaincopy
  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)截取字符串如下:

[cpp] view plaincopy
  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)判断手机号码,电话号码函数

[cpp] view plaincopy
  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. 10         * 中国移动:China Mobile
  13. 11         * 134[0-8],135,136,137,138,139,150,151,157,158,159,182,187,188
  14. 12         */
  15. NSString * CM = @"^1(34[0-8]|(3[5-9]|5[017-9]|8[278])\\d)\\d{7}$";
  16. /**
  17. 15         * 中国联通:China Unicom
  18. 16         * 130,131,132,152,155,156,185,186
  19. 17         */
  20. NSString * CU = @"^1(3[0-2]|5[256]|8[56])\\d{8}$";
  21. /**
  22. 20         * 中国电信:China Telecom
  23. 21         * 133,1349,153,180,189
  24. 22         */
  25. NSString * CT = @"^1((33|53|8[09])[0-9]|349)\\d{7}$";
  26. /**
  27. 25         * 大陆地区固话及小灵通
  28. 26         * 区号:010,020,021,022,023,024,025,027,028,029
  29. 27         * 号码:七位或八位
  30. 28         */
  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)邮箱验证、电话号码验证:

[cpp] view plaincopy
  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进行筛选

[cpp] view plaincopy
  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的本地模糊查询相关推荐

  1. mysql的模糊查询以及时间类型整理

    最近项目需求做模糊查询,大家也都知道,模糊查询是挺简单的,但难的是如何提升效率,,,当然在此咱们不说其他高深的,只针对mysql的模糊查询 1.mysql中除了like模糊查询,还有另一种模糊查询,F ...

  2. hibernate mysql 模糊查询_服务器-hibernate操作mysql,模糊查询时中文查不到,数字和英文可以查到...

    用hibernate做模糊查询,页面传递参数也处理了乱码 @Action(value="searchNameByad") public String searchNameByad( ...

  3. python数据库模糊查询_原创:Python编写通讯录,支持模糊查询,利用数据库存储...

    1.要求 数据库存储通讯录,要求按姓名/电话号码查询,查询条件只有一个输入入口,自动识别输入的是姓名还是号码,允许模糊查询. 2.实现功能 可通过输入指令进行操作. (1)首先输入"add& ...

  4. pythonsqlite3模糊_Python编写通讯录通过数据库存储实现模糊查询功能

    1.要求 数据库存储通讯录,要求按姓名/电话号码查询,查询条件只有一个输入入口,自动识别输入的是姓名还是号码,允许模糊查询. 2.实现功能 可通过输入指令进行操作. (1)首先输入"add& ...

  5. ios 查询mysql数据库操作系统_iOS数据库FMDB--增删改查(模糊查询)详细介绍

    简介: 很早就想整理一下数据库的使用了,刚好最近接触较多,加之可以安排出空余的时间,所以瓜子我贡献出自己喝咖啡的时间整理一下FMDB的使用,以下是对FMDB的介绍以及基本使用 --- insert.d ...

  6. 实现textbox输入时模糊查询

    时间有点紧,有点浮躁,暂时只把相关的文件挑出来看下,思路有时间再整理 1.引用的一个文件 代码 // JScript 文件 //************************************ ...

  7. 前端实现模糊查询不区分大小写

    首先,在js中转大小写的方法都有哪些? 在javascript中,转大写/小写的方法有toLocaleLowerCase().toLocaleUpperCase().toLowerCase()以及to ...

  8. vue实现input输入模糊查询(三种方式)

    vue实现input输入模糊查询(三种方式) 目录 vue实现input输入模糊查询(三种方式) 1 计算属性实现模糊查询 演示: 2 watch 监听实现模糊查询 3 通过按钮点击实现模糊查询 演示 ...

  9. 微信小程序 连接云数据库(不使用云函数)进行 登录、注册、查询(包括模糊查询)快速实现 亲测可用

    当连接MySQL的时候总是出现各种各样的小问题,可以选用微信小程序自带的云数据库 目 录 建立云数据库 建表 导入MySQL中的表 导出 导入 云数据库初始化 登录注册 注册功能 登录功能 查询(模糊 ...

最新文章

  1. 分分钟掌握设计基本原则
  2. Oracle根据符合条件的数据循环批量更新
  3. 彻底理解kafka中partition和消费者对应关系
  4. python3.5怎么安装pip-在python3.5中使用pip
  5. Android 手把手教您自定义ViewGroup
  6. 网站服务器基本防范配置
  7. order by、group by也会使用索引?使用这俩关键字的时候索引什么时间会失效
  8. Hive 基础(2):库、表、字段、交互式查询的基本操作
  9. python 基本数据类型常用方法总结
  10. Wamp升级php到7.3版本
  11. VS code常用插件推荐(总结整理篇)
  12. pythons实现信号分帧
  13. 华为牛人在华为工作十年的感悟!--总结[华为的10年工作]
  14. java 多线程:开两个线程,一个线程跑同步代码块,一个线程跑同步函数
  15. 数据结构中数据元素与数据项的区别
  16. 中兴B860AV2.1、1.1T、2.1-A-M-T,通刷线刷固件及教程
  17. 跨考计算机 专硕还是学硕,考研我该如何抉择!专硕学硕不纠结
  18. html js 在文本框选择自动计算乘,怎么让JS实现在文本框中输入数字时,同时输出这个数字,并再输出一个乘以0.39的值?...
  19. emmx文件用什么软件打开电脑_我告诉你emmx文件怎么打开
  20. 【Mqtt】基于paho.mqtt.c库的mqtt客户端实现

热门文章

  1. 学习笔记:有源晶振与无源晶振(一)
  2. 网络测试仪哪个牌子好
  3. 特步:云共享服务,点亮“新零售”
  4. python爬取bili评论
  5. PI数据库开发-java(读写pi中的时序数据和关系数据)
  6. R语言中ARMA,ARIMA(Box-Jenkins),SARIMA和ARIMAX模型用于预测时间序列数据
  7. 计算机主机漏电,电脑主机箱漏电六大原因和解决方法
  8. HTML生日快乐代码 HTML5七夕情人节表白【告白模板】 HTML5七夕情人节表白网页源码 html css javascript
  9. 第三集 Spring for Apache Kafka 接受消息
  10. Computer vision for solid waste sorting: A critical review of academic research 机器视觉垃圾分选综述翻译