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

相关文章

C语言中%zu的用法解读

《C语言中%zu的用法解读》size_t是无符号整数类型,用于表示对象大小或内存操作结果,%zu是C99标准中专为size_t设计的printf占位符,避免因类型不匹配导致错误,使用%u或%d可能引发... 目录size_t 类型与 %zu 占位符%zu 的用途替代占位符的风险兼容性说明其他相关占位符验证示

MySQL中EXISTS与IN用法使用与对比分析

《MySQL中EXISTS与IN用法使用与对比分析》在MySQL中,EXISTS和IN都用于子查询中根据另一个查询的结果来过滤主查询的记录,本文将基于工作原理、效率和应用场景进行全面对比... 目录一、基本用法详解1. IN 运算符2. EXISTS 运算符二、EXISTS 与 IN 的选择策略三、性能对比

全面解析Golang 中的 Gorilla CORS 中间件正确用法

《全面解析Golang中的GorillaCORS中间件正确用法》Golang中使用gorilla/mux路由器配合rs/cors中间件库可以优雅地解决这个问题,然而,很多人刚开始使用时会遇到配... 目录如何让 golang 中的 Gorilla CORS 中间件正确工作一、基础依赖二、错误用法(很多人一开

Java Stream流之GroupBy的用法及应用场景

《JavaStream流之GroupBy的用法及应用场景》本教程将详细介绍如何在Java中使用Stream流的groupby方法,包括基本用法和一些常见的实际应用场景,感兴趣的朋友一起看看吧... 目录Java Stream流之GroupBy的用法1. 前言2. 基础概念什么是 GroupBy?Stream

Java Spring的依赖注入理解及@Autowired用法示例详解

《JavaSpring的依赖注入理解及@Autowired用法示例详解》文章介绍了Spring依赖注入(DI)的概念、三种实现方式(构造器、Setter、字段注入),区分了@Autowired(注入... 目录一、什么是依赖注入(DI)?1. 定义2. 举个例子二、依赖注入的几种方式1. 构造器注入(Con

详解MySQL中JSON数据类型用法及与传统JSON字符串对比

《详解MySQL中JSON数据类型用法及与传统JSON字符串对比》MySQL从5.7版本开始引入了JSON数据类型,专门用于存储JSON格式的数据,本文将为大家简单介绍一下MySQL中JSON数据类型... 目录前言基本用法jsON数据类型 vs 传统JSON字符串1. 存储方式2. 查询方式对比3. 索引

全面掌握 SQL 中的 DATEDIFF函数及用法最佳实践

《全面掌握SQL中的DATEDIFF函数及用法最佳实践》本文解析DATEDIFF在不同数据库中的差异,强调其边界计算原理,探讨应用场景及陷阱,推荐根据需求选择TIMESTAMPDIFF或inte... 目录1. 核心概念:DATEDIFF 究竟在计算什么?2. 主流数据库中的 DATEDIFF 实现2.1

MySQL中的LENGTH()函数用法详解与实例分析

《MySQL中的LENGTH()函数用法详解与实例分析》MySQLLENGTH()函数用于计算字符串的字节长度,区别于CHAR_LENGTH()的字符长度,适用于多字节字符集(如UTF-8)的数据验证... 目录1. LENGTH()函数的基本语法2. LENGTH()函数的返回值2.1 示例1:计算字符串

Java中的数组与集合基本用法详解

《Java中的数组与集合基本用法详解》本文介绍了Java数组和集合框架的基础知识,数组部分涵盖了一维、二维及多维数组的声明、初始化、访问与遍历方法,以及Arrays类的常用操作,对Java数组与集合相... 目录一、Java数组基础1.1 数组结构概述1.2 一维数组1.2.1 声明与初始化1.2.2 访问

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

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