NSPredicate相关用法

2024-06-04 06:32
文章标签 用法 相关 nspredicate

本文主要是介绍NSPredicate相关用法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

http://blog.csdn.net/zfx5130/article/details/43372955

  NSPredicate   

       NSPredicate是一个Foundation类,它指定数据被获取或者过滤的方式。

      它的查询语言就像SQL的WHERE和正则表达式的交叉一样,提供了具有表现力的,自然语言界面来定义一个集合被搜寻的逻辑条件。

      NSPredicate的几种用法

      ①常见形式

   NSPredicate *predicate = [NSPredicate predicateWithFormat:@"name == 'zhangdan'"];//注意:如果谓词串中的文本块未被引用,则被看做是键路径,即需要用引号表明是字符串,单引号,双引号均可.键路径可以在后台包含许多强大的功能
    ②计算谓词

      让谓词通过某个对象来计算自己的值,给出BOOL值.例如:

     NSPredicate  *predicate = [NSPredicate predicateWithFormat: @"name == 'zhangsan'"];BOOL match = [predicate evaluateWithObject: person];NSLog (@"%s", (match) ? "YES" : "NO");//注上面的person是人对象
      ③燃料过滤器

        filteredArrayUsingPredicate:是NSArray数组的一种类别方法,循环过滤数组中的内容,将值为YES的对象累积到结果数组中返回.

 NSPredicate  *predicate = [NSPredicate predicateWithFormat:@"n"];NSArray *results = [arr filteredArrayUsingPredicate: predicate]; NSLog (@"%@", results);

 
     ④格式说明书 
 

     %d和%@表示插入数值和字符串,%K表示key    还可以引入变量名,用$,类似环境变量,如:@"name == $NAME",再用predicateWithSubstitutionVariables调用来构造新的谓词(键/值字典),其中键是变量名,值是要插入的内容,注意这种情况下不能把变量当成键路径,只能用作值.

  predicate = [NSPredicate predicateWithFormat: @"name == %@", @"zhangsan"];predicate = [NSPredicate predicateWithFormat: @"%K == %@", @"name", @"zhangsan"];NSPredicate *predicateTemplate =[NSPredicate predicateWithFormat:@"name == $NAME"];NSDictionary *dic = [NSDictionary dictionaryWithObjectsAndKeys:@"zhangsan", @"NAME", nil];NSPredicate *predicate = [predicateTemplate predicateWithSubstitutionVariables: dic];NSLog(@"%@", predicate);
     ⑤比较和逻辑运算符

    ==等于    >:大于     >=和=>:大于或等于    <:小于    <=和=<:小于或等于    !=和<>:不等于
    括号和逻辑运算AND、OR、NOT或者C样式的等效表达式&&   ||    !
    注意:不等号适用于数字和字符串

    NSArray *arrayFilter = [NSArray arrayWithObjects:@"abc1", @"abc2", nil];NSArray *arrayContent = [NSArray arrayWithObjects:@"a1",@"abc1", @"abc4", @"abc2", nil];NSPredicate *thePredicate = [NSPredicate predicateWithFormat:@"NOT (SELF in %@)", arrayFilter];[arrayContent filterUsingPredicate:thePredicate];
    ⑥数组字符串
    BETWEEN和IN后加某个数组,可以用{50,200},也可以用%@格式说明符插入自己的对象,也可以用变量.

    predicate = [NSPredicate predicateWithFormat:@"engine.horsepower BETWEEN { 50, 200 }"];results = [cars filteredArrayUsingPredicate: predicate];NSLog (@"%@", results);predicate = [NSPredicate predicateWithFormat: @"name IN { 'Herbie', 'Snugs', 'Badger', 'Flap' }"];results = [cars filteredArrayUsingPredicate: predicate];NSLog (@"%@", [results valueForKey: @"name"]);
      ⑦.字符串运算符

     BEGINSWITH        ENDSWITH         CONTAINS
     [c]:后缀表示不区分大小写       [d]:不区分发音符号      [cd]:后缀不区分大小写和不区分发音符号,
  例如:   @"name CONTAIN[cd] 'ang'"   //包含某个字符串
             @"name BEGINSWITH[c] 'sh'"     //以某个字符串开头
             @"name ENDSWITH[d] 'ang'"      //以某个字符串结束

    predicate = [NSPredicate predicateWithFormat: @"name BEGINSWITH 'Bad'"];results = [cars filteredArrayUsingPredicate: predicate];NSLog (@"%@", results);predicate = [NSPredicate predicateWithFormat: @"name ENDSWITH 'HERB'"];results = [cars filteredArrayUsingPredicate: predicate];NSLog (@"%@", results);predicate = [NSPredicate predicateWithFormat: @"name BEGINSWITH[cd] 'HERB'"];results = [cars filteredArrayUsingPredicate: predicate];NSLog (@"%@", results);

  ⑧.LIKE通配符--模糊查询(元字符 ? * )

  ? 匹配1个字符

  * 匹配多个字符

    LIKE:左边的表达式等于右边的表达式:?和*可作为通配符,其中?匹配1个字符,*匹配0个或者多个字符。
    LIKE也接受[cd]符号

    predicate = [NSPredicate predicateWithFormat: @"name LIKE[cd] '*er*'"];results = [cars filteredArrayUsingPredicate: predicate];NSLog (@"%@", results);predicate = [NSPredicate predicateWithFormat: @"name LIKE[cd] '???er*'"];results = [cars filteredArrayUsingPredicate: predicate];NSLog (@"%@", results);

⑨.MATCHES可以使用正则表达式

? 匹配1个字符

 * 匹配多个字符

 .  匹配任何单个字符

 ^ 匹配一行的首个字符串

 []  匹配括号内任意一个字符 .例如[a-zA-Z]

 +  匹配多个正好在它前面的字符
    NSString *regex1 = @"^A.+e$";   //以A开头,e结尾NSString *regex = @"[A-Za-z]+";NSPredicate *predicate = [NSPredicate predicateWithFormat:@"SELF MATCHES %@", regex];if ([predicate evaluateWithObject:aString]) {}
⑩.self就表示对象本身

    NSArray *arrayFilter = [NSArray arrayWithObjects:@"abc1", @"abc2", nil];NSArray *arrayContent = [NSArray arrayWithObjects:@"a1", @"abc1", @"abc4", @"abc2", nil];NSPredicate *thePredicate = [NSPredicate predicateWithFormat:@"NOT (SELF in %@)", arrayFilter];[arrayContent filterUsingPredicate:thePredicate];
①①.合计操作

   ANY,SOME:指定下列表达式中的任意元素。比如,ANY children.age < 18。
    ALL:指定下列表达式中的所有元素。比如,ALL children.age < 18。
    NONE:指定下列表达式中没有的元素。比如,NONE children.age < 18。它在逻辑上等于NOT (ANY ...)。
    IN:等于SQL的IN操作,左边的表达必须出现在右边指定的集合中。比如,name IN { 'Ben', 'Melissa', 'Nick' }。

①②.NSPredicate +predicateWithBlock:(块语法)

   NSPredicate *shortNamePredicate = [NSPredicate predicateWithBlock:^BOOL(id evaluatedObject, NSDictionary *bindings) {return [[evaluatedObject firstName] length] <= 5;}];// ["Alice Smith", "Bob Jones"]NSLog(@"Short Names: %@", [people filteredArrayUsingPredicate:shortNamePredicate]);
①③.NSCompoundPredicate
我们见过与&或被用在谓词格式字符串中以创建复合谓词。然而,我们也可以用NSCompoundPredicate来完成同样的工作。

<span style="font-size:18px;">    //例如,下列谓词是相等的:[NSCompoundPredicate andPredicateWithSubpredicates:@[[NSPredicate predicateWithFormat:@"age > 25"], [NSPredicate predicateWithFormat:@"firstName = %@", @"Quentin"]]];[NSPredicate predicateWithFormat:@"(age > 25) AND (firstName = %@)", @"Quentin"];</span>

谓词和正则表达式的综合:(判断手机号码,电话号码函数)

- (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}$";/*** 中国移动:China Mobile* 134[0-8],135,136,137,138,139,150,151,157,158,159,182,187,188*/NSString * CM = @"^1(34[0-8]|(3[5-9]|5[017-9]|8[278])\\d)\\d{7}$";/*** 中国联通:China Unicom* 130,131,132,152,155,156,185,186*/NSString * CU = @"^1(3[0-2]|5[256]|8[56])\\d{8}$";/*** 中国电信:China Telecom* 133,1349,153,180,189*/NSString * CT = @"^1((33|53|8[09])[0-9]|349)\\d{7}$";/*** 大陆地区固话及小灵通* 区号:010,020,021,022,023,024,025,027,028,029* 号码:七位或八位*/// 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;}
}

这篇关于NSPredicate相关用法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1029320

相关文章

MySQL 中的 CAST 函数详解及常见用法

《MySQL中的CAST函数详解及常见用法》CAST函数是MySQL中用于数据类型转换的重要函数,它允许你将一个值从一种数据类型转换为另一种数据类型,本文给大家介绍MySQL中的CAST... 目录mysql 中的 CAST 函数详解一、基本语法二、支持的数据类型三、常见用法示例1. 字符串转数字2. 数字

Python中你不知道的gzip高级用法分享

《Python中你不知道的gzip高级用法分享》在当今大数据时代,数据存储和传输成本已成为每个开发者必须考虑的问题,Python内置的gzip模块提供了一种简单高效的解决方案,下面小编就来和大家详细讲... 目录前言:为什么数据压缩如此重要1. gzip 模块基础介绍2. 基本压缩与解压缩操作2.1 压缩文

解读GC日志中的各项指标用法

《解读GC日志中的各项指标用法》:本文主要介绍GC日志中的各项指标用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、基础 GC 日志格式(以 G1 为例)1. Minor GC 日志2. Full GC 日志二、关键指标解析1. GC 类型与触发原因2. 堆

MySQL数据库中ENUM的用法是什么详解

《MySQL数据库中ENUM的用法是什么详解》ENUM是一个字符串对象,用于指定一组预定义的值,并可在创建表时使用,下面:本文主要介绍MySQL数据库中ENUM的用法是什么的相关资料,文中通过代码... 目录mysql 中 ENUM 的用法一、ENUM 的定义与语法二、ENUM 的特点三、ENUM 的用法1

JavaSE正则表达式用法总结大全

《JavaSE正则表达式用法总结大全》正则表达式就是由一些特定的字符组成,代表的是一个规则,:本文主要介绍JavaSE正则表达式用法的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录常用的正则表达式匹配符正则表China编程达式常用的类Pattern类Matcher类PatternSynta

MySQL之InnoDB存储引擎中的索引用法及说明

《MySQL之InnoDB存储引擎中的索引用法及说明》:本文主要介绍MySQL之InnoDB存储引擎中的索引用法及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录1、背景2、准备3、正篇【1】存储用户记录的数据页【2】存储目录项记录的数据页【3】聚簇索引【4】二

mysql中的数据目录用法及说明

《mysql中的数据目录用法及说明》:本文主要介绍mysql中的数据目录用法及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、版本3、数据目录4、总结1、背景安装mysql之后,在安装目录下会有一个data目录,我们创建的数据库、创建的表、插入的

深度解析Python装饰器常见用法与进阶技巧

《深度解析Python装饰器常见用法与进阶技巧》Python装饰器(Decorator)是提升代码可读性与复用性的强大工具,本文将深入解析Python装饰器的原理,常见用法,进阶技巧与最佳实践,希望可... 目录装饰器的基本原理函数装饰器的常见用法带参数的装饰器类装饰器与方法装饰器装饰器的嵌套与组合进阶技巧

Mysql中isnull,ifnull,nullif的用法及语义详解

《Mysql中isnull,ifnull,nullif的用法及语义详解》MySQL中ISNULL判断表达式是否为NULL,IFNULL替换NULL值为指定值,NULLIF在表达式相等时返回NULL,用... 目录mysql中isnull,ifnull,nullif的用法1. ISNULL(expr) → 判

Java中的for循环高级用法

《Java中的for循环高级用法》本文系统解析Java中传统、增强型for循环、StreamAPI及并行流的实现原理与性能差异,并通过大量代码示例展示实际开发中的最佳实践,感兴趣的朋友一起看看吧... 目录前言一、基础篇:传统for循环1.1 标准语法结构1.2 典型应用场景二、进阶篇:增强型for循环2.