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
模糊查询: where 字段 like'%字符串%' 精确查询: where find_in_set('精确字符串',字段名) 转载于:https://www.cnblogs.com/26055490 ...
- mongotemplate模糊查_java 中 mongodb的各种操作 模糊查询 精确查询 等等
本意是想查查mongo数据库的int类型的like怎么查,但是好像没 解决这个问题. 精确查询:模糊查询:分页查询,每页多少:按某个字段排序(或升或降):查询数量:大于,小于,等于:且,或,某个字段不 ...
- vc mysql 查询_VC++数据库模糊查询及精确查询示例代码分享
VC++数据库模糊查询及精确查询示例代码分享是小编为大家带来的一个VC++电话簿程序中的模糊查询例子源代码,结合数据库,可以学习研究下简单一点的模糊查询和精确查询,希望能对大家有帮助,,赶紧来详细了解 ...
- Mongotemplate mongodb的各种操作 模糊查询 精确查询
mongotemplate mongodb的各种操作 模糊查询 精确查询 - 门罗的魔术师 - 博客园
- 精确查询和模糊查询,前端往后端传值
xqbm 的精确查询: if(StringUtils.isNotBlank(params.get("xqbm"))){wrapper.eq(GjWiredNetwork::getX ...
- xadmin oracle 查询,Django admin 实现search_fields精确查询实例
我就废话不多说了,还是直接看代码吧! search_fields = (u'gift_rule_id',u'user_id', u'activity_id',) //默认的查询集合 def get_q ...
- mysql模糊连接查询_mysql 模糊查询 concat()
concat() 函数,是用来连接字符串. 精确查询: select * from user where name="zhangsan" 模糊查询: select * from u ...
- 【VBAPlanet】如何实现数据精确查询与匹配
大家好,我是海林,今天跟大家分享的VBA小代码主题是数据精确查询与匹配. 我们用王者荣耀的数据来举例,如下图所示.根据A:C列的数据源信息,查询E列英雄名相应的职业类型,如果查询无结果,则返回空白. ...
- php多关键词精确查找,搜索引擎,全文搜索_请问有没有搜索引擎能做到Like级别的任意关键词精确查询?,搜索引擎,全文搜索,lucene,elasticsearch,百度 - phpStudy...
请问有没有搜索引擎能做到Like级别的任意关键词精确查询? 举个例子,对于新闻[http://tech.163.com/15/0323/07/ALCIH40U000915BF.html],在正文中,按 ...
- Excel 中使用SQL 语句查询数据(七)-----用LIKE 运算符进行模糊匹配查询
这篇博文要和大家分享的是用LIKE 运算符进行模糊匹配查询下图数据源商品代号包含数字的数据. 我们用Microsoft query连接数据源,步骤请参考本系列第一篇博文.语句如下图 其中 LIKE ' ...
最新文章
- 使用FileUpload控件上传图片并自动生成缩略图、自动生成带文字和图片的水印图
- 刚刚,arXiv论文数破200万!没有arXiv,就没有21世纪的科研突破
- [M]MagicTable转换异常解决方法
- 重磅解读 | 赵义博:量子密码的绝对安全只存在于理论
- Java使用HTTPClient4.3开发的公众平台消息模板的推送功能
- 使用和执行SQL Server Integration Services包的方法
- 进退两难的硅谷程序员们
- POJ1741 点分治模板
- js:toastr弹出提示信息
- Python爬虫入门教程第七讲: 蜂鸟网图片爬取之二
- 千锋php 靠谱吗,千锋PHP学员心得 长久的坚持不懈才能接近成功
- 我有一壶酒,足以慰风尘
- 我是鉴黄师,在工作中遇到了我的前女友……
- Android性能优化系列之Bitmap图片优化
- 跟锦数学2017年02月
- pdf大小如何压缩?
- 电气成套设备远程监控应用
- 《第一行代码》学习笔记——第1章 开始启程,你的第一行Android代码
- js添加、删除DOM元素
- 这个必用的开发框架,是多少程序员头秃的存在?