NSPredicate的本地模糊查询
定义(最常用到的方法):
- 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进行过滤
- NSArray *array = [[NSArray alloc]initWithObjects:@"beijing",@"shanghai",@"guangzou",@"wuhan", nil];
- NSString *string = @"ang";
- NSPredicate *pred = [NSPredicate predicateWithFormat:@"SELF CONTAINS %@",string];
- NSLog(@"%@",[array filteredArrayUsingPredicate:pred]);
(2)判断字符串首字母是否为字母:
- NSString *regex = @"[A-Za-z]+";
- NSPredicate *predicate = [NSPredicate predicateWithFormat:@"SELF MATCHES %@", regex];
- if ([predicate evaluateWithObject:aString]) {
- }
(3)字符串替换:
- 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);
(4)截取字符串如下:
- //组装一个字符串,需要把里面的网址解析出来
- 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);
- }
- }
(5)判断手机号码,电话号码函数
- // 正则判断手机号码地址格式
- - (BOOL)isMobileNumber:(NSString *)mobileNum
- {
- /**
- * 手机号码
- * 移动:134[0-8],135,136,137,138,139,150,151,157,158,159,182,187,188
- * 联通:130,131,132,152,155,156,185,186
- * 电信:133,1349,153,180,189
- */
- NSString * MOBILE = @"^1(3[0-9]|5[0-35-9]|8[025-9])\\d{8}$";
- /**
- 10 * 中国移动:China Mobile
- 11 * 134[0-8],135,136,137,138,139,150,151,157,158,159,182,187,188
- 12 */
- NSString * CM = @"^1(34[0-8]|(3[5-9]|5[017-9]|8[278])\\d)\\d{7}$";
- /**
- 15 * 中国联通:China Unicom
- 16 * 130,131,132,152,155,156,185,186
- 17 */
- NSString * CU = @"^1(3[0-2]|5[256]|8[56])\\d{8}$";
- /**
- 20 * 中国电信:China Telecom
- 21 * 133,1349,153,180,189
- 22 */
- NSString * CT = @"^1((33|53|8[09])[0-9]|349)\\d{7}$";
- /**
- 25 * 大陆地区固话及小灵通
- 26 * 区号:010,020,021,022,023,024,025,027,028,029
- 27 * 号码:七位或八位
- 28 */
- // NSString * PHS = @"^0(10|2[0-5789]|\\d{3})\\d{7,8}$";
- NSPredicate *regextestmobile = [NSPredicate predicateWithFormat:@"SELF MATCHES %@", MOBILE];
- NSPredicate *regextestcm = [NSPredicate predicateWithFormat:@"SELF MATCHES %@", CM];
- NSPredicate *regextestcu = [NSPredicate predicateWithFormat:@"SELF MATCHES %@", CU];
- NSPredicate *regextestct = [NSPredicate predicateWithFormat:@"SELF MATCHES %@", CT];
- if (([regextestmobile evaluateWithObject:mobileNum] == YES)
- || ([regextestcm evaluateWithObject:mobileNum] == YES)
- || ([regextestct evaluateWithObject:mobileNum] == YES)
- || ([regextestcu evaluateWithObject:mobileNum] == YES))
- {
- if([regextestcm evaluateWithObject:mobileNum] == YES) {
- NSLog(@"China Mobile");
- } else if([regextestct evaluateWithObject:mobileNum] == YES) {
- NSLog(@"China Telecom");
- } else if ([regextestcu evaluateWithObject:mobileNum] == YES) {
- NSLog(@"China Unicom");
- } else {
- NSLog(@"Unknow");
- }
- return YES;
- }
- else
- {
- return NO;
- }
- }
(6)邮箱验证、电话号码验证:
- //是否是有效的正则表达式
- +(BOOL)isValidateRegularExpression:(NSString *)strDestination byExpression:(NSString *)strExpression
- {
- NSPredicate *predicate = [NSPredicatepredicateWithFormat:@"SELF MATCHES %@", strExpression];
- return [predicate evaluateWithObject:strDestination];
- }
- //验证email
- +(BOOL)isValidateEmail:(NSString *)email {
- NSString *strRegex = @"[A-Z0-9a-z._%+-]+@[A-Za-z0-9.-]+\\.[A-Za-z]{1,5}";
- BOOL rt = [CommonTools isValidateRegularExpression:email byExpression:strRegex];
- return rt;
- }
- //验证电话号码
- +(BOOL)isValidateTelNumber:(NSString *)number {
- NSString *strRegex = @"[0-9]{1,20}";
- BOOL rt = [CommonTools isValidateRegularExpression:number byExpression:strRegex];
- return rt;
- }
(7)NSDate进行筛选
- //日期在十天之内:
- 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];
NSPredicate的本地模糊查询相关推荐
- mysql的模糊查询以及时间类型整理
最近项目需求做模糊查询,大家也都知道,模糊查询是挺简单的,但难的是如何提升效率,,,当然在此咱们不说其他高深的,只针对mysql的模糊查询 1.mysql中除了like模糊查询,还有另一种模糊查询,F ...
- hibernate mysql 模糊查询_服务器-hibernate操作mysql,模糊查询时中文查不到,数字和英文可以查到...
用hibernate做模糊查询,页面传递参数也处理了乱码 @Action(value="searchNameByad") public String searchNameByad( ...
- python数据库模糊查询_原创:Python编写通讯录,支持模糊查询,利用数据库存储...
1.要求 数据库存储通讯录,要求按姓名/电话号码查询,查询条件只有一个输入入口,自动识别输入的是姓名还是号码,允许模糊查询. 2.实现功能 可通过输入指令进行操作. (1)首先输入"add& ...
- pythonsqlite3模糊_Python编写通讯录通过数据库存储实现模糊查询功能
1.要求 数据库存储通讯录,要求按姓名/电话号码查询,查询条件只有一个输入入口,自动识别输入的是姓名还是号码,允许模糊查询. 2.实现功能 可通过输入指令进行操作. (1)首先输入"add& ...
- ios 查询mysql数据库操作系统_iOS数据库FMDB--增删改查(模糊查询)详细介绍
简介: 很早就想整理一下数据库的使用了,刚好最近接触较多,加之可以安排出空余的时间,所以瓜子我贡献出自己喝咖啡的时间整理一下FMDB的使用,以下是对FMDB的介绍以及基本使用 --- insert.d ...
- 实现textbox输入时模糊查询
时间有点紧,有点浮躁,暂时只把相关的文件挑出来看下,思路有时间再整理 1.引用的一个文件 代码 // JScript 文件 //************************************ ...
- 前端实现模糊查询不区分大小写
首先,在js中转大小写的方法都有哪些? 在javascript中,转大写/小写的方法有toLocaleLowerCase().toLocaleUpperCase().toLowerCase()以及to ...
- vue实现input输入模糊查询(三种方式)
vue实现input输入模糊查询(三种方式) 目录 vue实现input输入模糊查询(三种方式) 1 计算属性实现模糊查询 演示: 2 watch 监听实现模糊查询 3 通过按钮点击实现模糊查询 演示 ...
- 微信小程序 连接云数据库(不使用云函数)进行 登录、注册、查询(包括模糊查询)快速实现 亲测可用
当连接MySQL的时候总是出现各种各样的小问题,可以选用微信小程序自带的云数据库 目 录 建立云数据库 建表 导入MySQL中的表 导出 导入 云数据库初始化 登录注册 注册功能 登录功能 查询(模糊 ...
最新文章
- 分分钟掌握设计基本原则
- Oracle根据符合条件的数据循环批量更新
- 彻底理解kafka中partition和消费者对应关系
- python3.5怎么安装pip-在python3.5中使用pip
- Android 手把手教您自定义ViewGroup
- 网站服务器基本防范配置
- order by、group by也会使用索引?使用这俩关键字的时候索引什么时间会失效
- Hive 基础(2):库、表、字段、交互式查询的基本操作
- python 基本数据类型常用方法总结
- Wamp升级php到7.3版本
- VS code常用插件推荐(总结整理篇)
- pythons实现信号分帧
- 华为牛人在华为工作十年的感悟!--总结[华为的10年工作]
- java 多线程:开两个线程,一个线程跑同步代码块,一个线程跑同步函数
- 数据结构中数据元素与数据项的区别
- 中兴B860AV2.1、1.1T、2.1-A-M-T,通刷线刷固件及教程
- 跨考计算机 专硕还是学硕,考研我该如何抉择!专硕学硕不纠结
- html js 在文本框选择自动计算乘,怎么让JS实现在文本框中输入数字时,同时输出这个数字,并再输出一个乘以0.39的值?...
- emmx文件用什么软件打开电脑_我告诉你emmx文件怎么打开
- 【Mqtt】基于paho.mqtt.c库的mqtt客户端实现
热门文章
- 学习笔记:有源晶振与无源晶振(一)
- 网络测试仪哪个牌子好
- 特步:云共享服务,点亮“新零售”
- python爬取bili评论
- PI数据库开发-java(读写pi中的时序数据和关系数据)
- R语言中ARMA,ARIMA(Box-Jenkins),SARIMA和ARIMAX模型用于预测时间序列数据
- 计算机主机漏电,电脑主机箱漏电六大原因和解决方法
- HTML生日快乐代码 HTML5七夕情人节表白【告白模板】 HTML5七夕情人节表白网页源码 html css javascript
- 第三集 Spring for Apache Kafka 接受消息
- Computer vision for solid waste sorting: A critical review of academic research 机器视觉垃圾分选综述翻译