NSPredicate 查询/搜索

IOS NSPredicate 查询、搜索

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

最常用到的函数

+ (NSPredicate *)predicateWithFormat:(NSString *)predicateFormat, ...;

1.比较运算符 > 、< 、== 、 >= 、<= 、 !=
例:@"number >= 99"

2.范围运算符:IN 、BETWEEN
例:@"number BETWEEN {1,5}"
      @"address IN {‘shanghai‘,‘nanjing‘}"

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

实际应用:对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]);  

实际应用:判断字符串首字母是否为字母

NSString *regex = @"[A-Za-z]+";
NSPredicate *predicate = [NSPredicate predicateWithFormat:@"SELF MATCHES %@", regex];  

if ([predicate evaluateWithObject:aString]) {
}  

实际应用:字符串替换

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);  

实际应用:截取字符串

//组装一个字符串,需要把里面的网址解析出来
NSString *[email protected]"<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);
    }  

}  

实际应用:判断手机号码,电话号码函数

// 正则判断手机号码地址格式
- (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;
    }
}

实际应用:邮箱验证、电话号码验证

//是否是有效的正则表达式

+(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._%+-][email protected][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;

}

实际应用: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];
时间: 2024-11-05 02:38:42

NSPredicate 查询/搜索的相关文章

Android通讯录模糊查询搜索(号码,姓名,首字母简拼,全拼),批量选取联系人

Android通讯录模糊查询搜索(号码,姓名,首字母简拼,全拼),批量选取联系人 公司最近的项目中遇到一个需求需要读取通讯录联系人,并需要支持对联系人的模糊查询及批量选取,网上找了好几个例子,模糊查询这块处理的都有点小瑕疵,最终自己在各位网友的辛勤贡献基础之上进行了优化,最终做出了联系人模糊查询. 支持以下功能: 1.按 号码 , 姓名 , 首字母简拼 , 全拼 模糊查询 2.支持[A-Z]快速导航 3.支持联系人按首字母分类 4.支持联系人批量选取. 具体github地址:  https://

lucene多条件查询”搜索—BooleanQuery

/** * "多条件查询"搜索-BooleanQuery * BooleanQuery也是实际开发过程中经常使用的一种Query. * 它其实是一个组合的Query,在使用时可以把各种Query对象添加进去并标明它们之间的逻辑关系. * 在本节中所讨论的所有查询类型都可以使用BooleanQuery综合起来. * BooleanQuery本身来讲是一个布尔子句的容器,它提供了专门的API方法往其中添加子句, * 并标明它们之间的关系,以下代码为BooleanQuery提供的用于添加子句

向DataGrid数据表格增加查询搜索框

向DataGrid数据表格增加查询搜索框 效果如下: js代码: $(function(){ var dg = $('#dg').datagrid({ url:"${pageContext.request.contextPath}/OfferServlet",//servlet路径 columns:[[ {field:'offerid',title:'商品ID',width:100}, {field:'offername',title:'商品名称',width:100}, {field

NSPredicate谓词搜索使用小记

iOS中的搜索正常情况下用NSPredicate都足以解决问题,比如我们有一个原数组_dataArraty: NSPredicate*predicate =[NSPredicate predicateWithFormat:@"name like %@", searchTexts]; NSArray * resultArr = [_dataArray filteredArrayUsingPredicate:predicate]; like语法可以匹配搜索 一般情况下,搜索是否包含某个字符

Symfony3 查询搜索功能DQL语句like查询

//前台页面代码 <form method="GET" action="{{ path('staff_index') }}" name="searchterm"> <label> <input name="searchterm" type="text" value="" placeholder="输入名称" > </label

Yii 查询 搜索

一.视图 <div class="form-horizontal"> <?php $form = $this->beginWidget('CActiveForm', array('id' => 'course', 'action' => '/admin/mp/')); ?> <div class="form-group"> <div class="col-md-2"> <?p

Android第五十期 - 仿美团查询搜索ListView+PopupWindow

代码已经整理好,效果如下图: 地址:http://down.51cto.com/data/2093827

查询搜索指令

1.在某个路径下查找一个指定的文件: find pathname -name "filename" eg: find /usr/ -name "stdio.h" //在usr目录下查找stdio.h头文件. 2.在某个路径下查找包含一个指定的字符串的所有文件: grep -rl "stringname" pathname eg:grep -rl "BUFSIZ" ./ //在当前目录下查找包含宏"BUFSIZ&quo

2.10 文件查询搜索命令

原文地址:https://www.cnblogs.com/wbly2019/p/10749644.html