OC中的谓词操作是针对于数组类型的,他就好比数据库中的查询操作,数据源就是数组,这样的好处是我们不需要编写很多代码就可以去操作数组,同时也起到过滤的作用,我们可以编写简单的谓词语句,就可以从数组中过滤出我们想要的数据。非常方便。在Java中是没有这种技术的,但是有开源的框架已经实现了此功能。

下面来看一下具体的例子吧:

Person.h

  1. //
  2. //  Person.h
  3. //  46_NSPredicate
  4. //
  5. //  Created by jiangwei on 14-10-18.
  6. //  Copyright (c) 2014年 jiangwei. All rights reserved.
  7. //
  8. #import <Foundation/Foundation.h>
  9. @interface Person : NSObject
  10. @property NSString *name;
  11. @property NSInteger age;
  12. + (id)personWithName:(NSString *)name andAge:(NSInteger)age;
  13. @end

Person.m

  1. //
  2. //  Person.m
  3. //  46_NSPredicate
  4. //
  5. //  Created by jiangwei on 14-10-18.
  6. //  Copyright (c) 2014年 jiangwei. All rights reserved.
  7. //
  8. #import "Person.h"
  9. @implementation Person
  10. + (id)personWithName:(NSString *)name andAge:(NSInteger)age{
  11. Person *person = [[Person alloc] init];
  12. person.name = name;
  13. person.age = age;
  14. return person;
  15. }
  16. - (NSString *)description{
  17. NSString *s =[NSString stringWithFormat:@"name=%@,age=%ld",_name,_age];
  18. return s;
  19. }
  20. @end

我们在Person类中定义属性,还有一个产生对象的类方法,同时重写了description方法,用于打印结果

测试方法

main.m

  1. //
  2. //  main.m
  3. //  46_NSPredicate
  4. //
  5. //  Created by jiangwei on 14-10-18.
  6. //  Copyright (c) 2014年 jiangwei. All rights reserved.
  7. //
  8. #import <Foundation/Foundation.h>
  9. #import "Person.h"
  10. //谓词,指定过滤器的条件,将符合条件的对象保留下来
  11. //一般用谓词过滤数组中指定的元素
  12. int main(int argc, const charchar * argv[]) {
  13. @autoreleasepool {
  14. NSArray *persons = [NSArray arrayWithObjects:
  15. [Person personWithName:@"mac" andAge:20],
  16. [Person personWithName:@"1" andAge:30],
  17. [Person personWithName:@"2" andAge:40],
  18. [Person personWithName:@"3" andAge:50],
  19. [Person personWithName:@"4" andAge:60],
  20. [Person personWithName:@"5" andAge:70],
  21. [Person personWithName:@"6" andAge:20],
  22. [Person personWithName:@"7" andAge:40],
  23. [Person personWithName:@"8" andAge:60],
  24. [Person personWithName:@"9" andAge:40],
  25. [Person personWithName:@"0" andAge:80],
  26. [Person personWithName:@"10" andAge:90],
  27. [Person personWithName:@"1" andAge:20]];
  28. //年龄小于30
  29. //定义谓词对象,谓词对象中包含了过滤条件
  30. NSPredicate *predicate = [NSPredicate predicateWithFormat:@"age<%d",30];
  31. //使用谓词条件过滤数组中的元素,过滤之后返回查询的结果
  32. NSArray *array = [persons filteredArrayUsingPredicate:predicate];
  33. NSLog(@"filterArray=%@",array);
  34. //查询name=1的并且age大于40
  35. predicate = [NSPredicate predicateWithFormat:@"name='1' && age>40"];
  36. array = [persons filteredArrayUsingPredicate:predicate];
  37. NSLog(@"filterArray=%@",array);
  38. //in(包含)
  39. predicate = [NSPredicate predicateWithFormat:@"self.name IN {'1','2','4'} || self.age IN{30,40}"];
  40. //name以a开头的
  41. predicate = [NSPredicate predicateWithFormat:@"name BEGINSWITH 'a'"];
  42. //name以ba结尾的
  43. predicate = [NSPredicate predicateWithFormat:@"name ENDSWITH 'ba'"];
  44. //name中包含字符a的
  45. predicate = [NSPredicate predicateWithFormat:@"name CONTAINS 'a'"];
  46. //like 匹配任意多个字符
  47. //name中只要有s字符就满足条件
  48. predicate = [NSPredicate predicateWithFormat:@"name like '*s*'"];
  49. //?代表一个字符,下面的查询条件是:name中第二个字符是s的
  50. predicate = [NSPredicate predicateWithFormat:@"name like '?s'"];
  51. }
  52. return 0;
  53. }

首先我们看到,我们初始化了一定大小的数组。

然后我们就可以使用NSPredicate类进行过滤操作了

1、查询数组中年龄小于30的对象

  1. //年龄小于30
  2. //定义谓词对象,谓词对象中包含了过滤条件
  3. NSPredicate *predicate = [NSPredicate predicateWithFormat:@"age<%d",30];
  4. //使用谓词条件过滤数组中的元素,过滤之后返回查询的结果
  5. NSArray *array = [persons filteredArrayUsingPredicate:predicate];
  6. NSLog(@"filterArray=%@",array);

首先创立一个过滤条件:

  1. //定义谓词对象,谓词对象中包含了过滤条件
  2. NSPredicate *predicate = [NSPredicate predicateWithFormat:@"age<%d",30];

这里面操作很简单的:@"age<%d",这个age是Person的属性名,%d相当于占位符,然后后面用参数替换即可

然后进行过滤操作,返回一个过滤之后的数组对象

  1. //使用谓词条件过滤数组中的元素,过滤之后返回查询的结果
  2. NSArray *array = [persons filteredArrayUsingPredicate:predicate];

2、查询name=1并且age大于40的集合

  1. //查询name=1的并且age大于40
  2. predicate = [NSPredicate predicateWithFormat:@"name='1' && age>40"];
  3. array = [persons filteredArrayUsingPredicate:predicate];
  4. NSLog(@"filterArray=%@",array);

当然我们也可以使用&&进行多条件过滤

3、包含语句的使用

  1. //in(包含)
  2. predicate = [NSPredicate predicateWithFormat:@"self.name IN {'1','2','4'} || self.age IN{30,40}"];

4、指定字符开头和指定字符结尾,是否包含指定字符

  1. //name以a开头的
  2. predicate = [NSPredicate predicateWithFormat:@"name BEGINSWITH 'a'"];
  3. //name以ba结尾的
  4. predicate = [NSPredicate predicateWithFormat:@"name ENDSWITH 'ba'"];
  5. //name中包含字符a的
  6. predicate = [NSPredicate predicateWithFormat:@"name CONTAINS 'a'"];

5、like进行匹配多个字符

    1. //like 匹配任意多个字符
    2. //name中只要有s字符就满足条件
    3. predicate = [NSPredicate predicateWithFormat:@"name like '*s*'"];
    4. //?代表一个字符,下面的查询条件是:name中第二个字符是s的
    5. predicate = [NSPredicate predicateWithFormat:@"name like '?s'"];

谓词(NSPredicate)的更多相关文章

  1. OC中给我们提供的一个技术:谓词(NSPredicate).note

    OC中给我们提供的一个技术:谓词(NSPredicate)OC中的谓词操作是针对于数组类型的,他就好比数据库中的查询操作,数据源就是数组,这样的好处是我们不需要编写很多代码就可以去操作数组,同时也起到 ...

  2. iOS:转载:IOS谓词--NSPredicate

    IOS谓词--NSPredicate 分类: IOS应用2013-02-19 17:24 6792人阅读 评论(1) 收藏 举报 Cocoa 提供了NSPredicate 用于指定过滤条件,谓词是指在 ...

  3. OC学习篇之---谓词(NSPredicate)

    在前一篇文章中我们介绍了OC中一个重要技术通知:http://blog.csdn.net/jiangwei0910410003/article/details/41923401,今天我们在来看一下OC ...

  4. 谓词 (NSPredicate)使用详情

    谓词 更加详细:http://blog.csdn.net/ztp800201/article/details/8116081 //判断是否满足条件 第一种 判断一个数组(array)中满足条件的 NS ...

  5. OC 之 谓词

    NSPredicate 分类: Objective-C iOS XCode Mac2012-10-26 17:26 10557人阅读 评论(1) 收藏 举报 简述:Cocoa框架中的NSPredica ...

  6. coredata中谓词的使用

    Cocoa提供了一个类NSPredicate类,该类主要用于指定过滤器的条件,该对象可以准确的描述所需条件,对每个对象通过谓词进行筛选,判断是否与条件相匹配.谓词表示计算真值或假值的函数.在cocoa ...

  7. iOS中谓词的使用

    Cocoa提供了一个类NSPredicate类,该类主要用于指定过滤器的条件,该对象可以准确的描述所需条件,对每个对象通过谓词进行筛选,判断是否与条件相匹配.谓词表示计算真值或假值的函数.在cocoa ...

  8. 【IOS 开发】Objective-C Foundation 框架 -- 字符串 | 日期 | 对象复制 | NSArray | NSSet | NSDictionary | 谓词

    一. 字符串 API 1. NSString 用法简介 (1) NSString API 介绍 NSString 功能 : -- 创建字符串 : 使用 init 开头的实例方法, 也可以使用 Stri ...

  9. NSPredicate的使用

    简述 NSPredicate谓词条件过滤器,一般用于过滤数组数据,原理和用法都类似于SQL中的where,作用相当于数据库的过滤取. 常用函数 创建谓词 + (NSPredicate *)predic ...

随机推荐

  1. 细说SQL性能优化

    1:在进行多表关联时,多用where语句把单个表的结果集最小化,多用聚合函数汇总结果集后再与其它表做关联,以使结果集数据量最小化2:在两张表进行关联时,应考虑可否使用右连接.以提高查询速度3:使用wh ...

  2. Linux kernel 拒绝服务漏洞

    漏洞名称: Linux kernel 拒绝服务漏洞 CNNVD编号: CNNVD-201311-020 发布时间: 2013-11-05 更新时间: 2013-11-05 危害等级:    漏洞类型: ...

  3. 自定义web服务器(四)

    关于HTTP协议的具体内容,前面章节已经有所讲解,相信读者已有所了解,在此不在累述,本章节讲解自定义web服务器.  一,.net提供自定义Web服务器的类 以下只是写主要的类 1.HTTPListe ...

  4. Dell笔记本禁用触摸板的方法

    一·找到触摸板驱动所在的文件夹(其他型号 的本本,请自己探索一下,找到驱动在哪就行),一般 在 C:\program files\delltpad 中(若没有请下载安 装 ),如图: 二·双击 Del ...

  5. js循环array,json,map

    var str = '[{"uname":"王强","day":"2010/06/17"},{"uname&q ...

  6. NameValueCollection类

    最近在研究HttpRequest类,发现里面的很多属性都返回一个NameValueCollection对象,今天再来了解一下这个神秘的对象. 随便写了个例子,发现跟HashTable类似.但是这个东西 ...

  7. Lua查找字符串注意

    问题: 使用Lua写Wireshark插件时,经常匹配字符串.今天使用string.find()函数查找字符串”max-age”,没有找到. 分析: local index = string.find ...

  8. Installing EF Power Tools into VS2015

    TLDR: If you don’t want to do the tasks (even though they are so easy) you can download the updated ...

  9. oracle logminer全解析

    今天写篇原创的,把在工作中遇到的logminer问题总结下 (1)简介: logminer 工具即可以用来分析在线,也可以用来分析离线日志文件,即可以分析本身自己数据库的重作日志文件,也可以用来分析其 ...

  10. 洛谷P1126 机器人搬重物

    洛谷1126 机器人搬重物 题目描述 机器人移动学会(RMI)现在正尝试用机器人搬运物品.机器人的形状是一个直径1.6米的球.在试验阶段,机器人被用于在一个储藏室中搬运货物.储藏室是一个N*M的网格, ...