在IOS开发Cocoa框架中提供了一个功能强大的类NSPredicate,下面来讨论一下它的强大之处在哪...
NSPredicate继承自NSObject,它有两个派生的子类
• NSComparisonPredicate
• NSCompoundPredicate (子类不是我们今天讨论的对象,暂且了解一下就行)
 说到谓词,我们先来看一下谓词的语法。
1.比较运算符
* >:大于
* <:小于
* >=:大于等于
* <=:小于等于
* =,==:等于
* !=,<>:不等于

2.逻辑运算符
   *and /&&和
   *or/||或
   *not/!非
3.关系运算符
   *ANY任意,SOME 一些
    *ALL所有元素
    *NONE没有元素 等同于not any
    *in包含
4.范围运算符
* between 如,1 BETWEEN { 0 , 33 },或者$INPUT BETWEEN { $LOWER, $UPPER }。
* in包含

4.字符串本身
   *SELF 如:@“self==‘APPLEIOS’”
5.字符串相关
   *contain
    *between
    *endswith
6.like通配符
   * like 如:@"name like[cd] '*ios*'"  
                 @"name" like[cd] 'ios*'"
7.正则表达式matches
     *如:NSString *regex = @"^A.+e$";   //以A开头,e结尾
        @"name MATCHES %@",regex
8.数组操作
       * array[index]:指定数组中特定索引处的元素。
       *array[first]:制定第一个元素
        *array[last]:制定最后一个元素
        *array[size]:制定数组大小
下面我们再来看一下具体的事例:

新建一个项目,然后添加类products

Products.h
 1 //
2 // Products.h
3 // NSPredicateTest
4 //
5 // Created by xuhongjiang on 15/10/27.
6 // Copyright (c) 2015年 xuhongjiang. All rights reserved.
7 //
8
9 #import <Foundation/Foundation.h>
10
11 @interface Products : NSObject
12 @property NSString *productName;
13 @property NSInteger productCount;
14 @property NSString *productImageUrl;
15 +(id)initProductWithName:(NSString *) name withCount:(NSInteger) count withImage:(NSString *) imageurl;
16 @end
Products.m
 1 //
2 // Products.m
3 // NSPredicateTest
4 //
5 // Created by xuhongjiang on 15/10/27.
6 // Copyright (c) 2015年 xuhongjiang. All rights reserved.
7 //
8
9 #import "Products.h"
10
11 @implementation Products
12 +(id)initProductWithName:(NSString *)name withCount:(NSInteger)count withImage:(NSString *)imageurl
13 {
14 Products *sprducts=[[Products alloc] init];
15 sprducts.productName=name;
16 sprducts.productCount=count;
17 sprducts.productImageUrl=imageurl;
18 return sprducts;
19 }
20 -(NSString *)description
21 {
22 NSString *str=[NSString stringWithFormat:@"产品名称:%@,数量:%ld,图片:%@",_productName,_productCount,_productImageUrl];
23 return str;
24 }
25 @end

测试方法:

  1 //
2 // ViewController.m
3 // NSPredicateTest
4 //
5 // Created by xuhongjiang on 15/10/27.
6 // Copyright (c) 2015年 xuhongjiang. All rights reserved.
7 //
8
9 #import "ViewController.h"
10 #import "Products.h"
11
12 @interface ViewController ()
13
14 @end
15
16 @implementation ViewController
17
18 - (void)viewDidLoad {
19 [super viewDidLoad];
20 [self mainTest];
21 }
22
23 - (void)didReceiveMemoryWarning {
24 [super didReceiveMemoryWarning];
25 }
26
27 -(void) mainTest
28 {
29 Products *p1=[Products initProductWithName:@"A苹果sdasf" withCount:2 withImage:@"464.jpg"];
30 Products *p2=[Products initProductWithName:@"fsdf橘子gag" withCount:53 withImage:@"fsdfas.jpg"];
31 Products *p3=[Products initProductWithName:@"dfgdf香蕉" withCount:5 withImage:@"sfas.jpg"];
32 Products *p4=[Products initProductWithName:@"三星" withCount:76 withImage:@"ggas.jpg"];
33 Products *p5=[Products initProductWithName:@"华为dfsd" withCount:9 withImage:@"gasa.jpg"];
34 Products *p6=[Products initProductWithName:@"微软dhnnne" withCount:6 withImage:@"hshhh.jpg"];
35 Products *p7=[Products initProductWithName:@"三星" withCount:6 withImage:@"hshhh.jpg"];
36 Products *p8=[Products initProductWithName:@"15300250500" withCount:6 withImage:@"hshhh.jpg"];
37
38 NSArray *sproducts=[NSArray arrayWithObjects:p1,p2,p3,p4,p5,p6,p7,nil];
39
40 //数量小于9 定义谓词 包含过滤条件
41 NSPredicate *prdicate=[NSPredicate predicateWithFormat:@"productCount<%d",9];
42 //过滤结果返回新的数组
43 NSArray *newArray=[sproducts filteredArrayUsingPredicate:prdicate];
44 for (Products *item in newArray) {
45 NSLog(@"newArray=%@",item.productName);
46 }
47
48
49 //数量大于9 并且productname等于“三星jfggg” 定义谓词 包含过滤条件
50 prdicate=[NSPredicate predicateWithFormat:@"productName='三星' && productCount>9"];
51 //过滤结果返回新的数组
52 newArray=[sproducts filteredArrayUsingPredicate:prdicate];
53 for (Products *item in newArray) {
54 NSLog(@"newArray=%@",item.productName);
55 }
56
57 //in(包含) *注意 包含是全字匹配
58 prdicate = [NSPredicate predicateWithFormat:@"productName IN {'g','华为','三星'}||productCount IN {2,5}"];
59 //过滤结果返回新的数组
60 newArray=[sproducts filteredArrayUsingPredicate:prdicate];
61 for (Products *item in newArray) {
62 NSLog(@"newArray=%@",item.productName);
63 }
64
65
66 //productName以a开头的
67 prdicate = [NSPredicate predicateWithFormat:@"productName BEGINSWITH 'A'"];
68 //productName以ba结尾的
69 prdicate = [NSPredicate predicateWithFormat:@"productName ENDSWITH 'g'"];
70
71 //name中包含字符a的
72 prdicate = [NSPredicate predicateWithFormat:@"productName CONTAINS 'a'"];
73
74 //like 匹配任意多个字符
75 //productName中只要有s字符就满足条件
76 prdicate = [NSPredicate predicateWithFormat:@"productName like '*s*'"];
77 //?代表一个字符,下面的查询条件是:name中第二个字符是s的
78 prdicate = [NSPredicate predicateWithFormat:@"productName like '?s*'"];
79
80 newArray=[sproducts filteredArrayUsingPredicate:prdicate];
81 for (Products *item in newArray) {
82 NSLog(@"newArray=%@",item.productName);
83 }
84
85 //正则表达式 验证是否是手机号
86 BOOL isMobileNum=[self isMobileNumber:p8.productName];
87 if(isMobileNum)
88 NSLog(@"是真确的手机号:%@",p8.productName);
89
90 }
91
92
93 - (BOOL)isMobileNumber:(NSString *)mobileNum
94 {
95 /**
96 * 手机号码
97 * 移动:134[0-8],135,136,137,138,139,150,151,157,158,159,182,187,188
98 * 联通:130,131,132,152,155,156,185,186
99 * 电信:133,1349,153,180,189
100 */
101 NSString * MOBILE = @"^1(3[0-9]|5[0-35-9]|8[025-9])\\d{8}$";
102 /**
103 10 * 中国移动:China Mobile
104 11 * 134[0-8],135,136,137,138,139,150,151,157,158,159,182,187,188
105 12 */
106 NSString * CM = @"^1(34[0-8]|(3[5-9]|5[017-9]|8[278])\\d)\\d{7}$";
107 /**
108 15 * 中国联通:China Unicom
109 16 * 130,131,132,152,155,156,185,186
110 17 */
111 NSString * CU = @"^1(3[0-2]|5[256]|8[56])\\d{8}$";
112 /**
113 20 * 中国电信:China Telecom
114 21 * 133,1349,153,180,189
115 22 */
116 NSString * CT = @"^1((33|53|8[09])[0-9]|349)\\d{7}$";
117 /**
118 25 * 大陆地区固话及小灵通
119 26 * 区号:010,020,021,022,023,024,025,027,028,029
120 27 * 号码:七位或八位
121 28 */
122 // NSString * PHS = @"^0(10|2[0-5789]|\\d{3})\\d{7,8}$";
123
124 NSPredicate *regextestmobile = [NSPredicate predicateWithFormat:@"SELF MATCHES %@", MOBILE];
125 NSPredicate *regextestcm = [NSPredicate predicateWithFormat:@"SELF MATCHES %@", CM];
126 NSPredicate *regextestcu = [NSPredicate predicateWithFormat:@"SELF MATCHES %@", CU];
127 NSPredicate *regextestct = [NSPredicate predicateWithFormat:@"SELF MATCHES %@", CT];
128
129 if (([regextestmobile evaluateWithObject:mobileNum] == YES)
130 || ([regextestcm evaluateWithObject:mobileNum] == YES)
131 || ([regextestct evaluateWithObject:mobileNum] == YES)
132 || ([regextestcu evaluateWithObject:mobileNum] == YES))
133 {
134 if([regextestcm evaluateWithObject:mobileNum] == YES) {
135 NSLog(@"中国移动");
136 } else if([regextestct evaluateWithObject:mobileNum] == YES) {
137 NSLog(@"联通");
138 } else if ([regextestcu evaluateWithObject:mobileNum] == YES) {
139 NSLog(@"电信");
140 } else {
141 NSLog(@"Unknow");
142 }
143
144 return YES;
145 }
146 else
147 {
148 return NO;
149 }
150 }
151 @end

1.查询产品数量小于9的产品

这里的代码很简单,第一步创建一个过滤器,用占位符替换数量9,过滤器返回一个新的数组,之后遍历数组,只取产品名称。

//数量小于9  定义谓词 包含过滤条件
NSPredicate *prdicate=[NSPredicate predicateWithFormat:@"productCount<%d",9];
//过滤结果返回新的数组
NSArray *newArray=[sproducts filteredArrayUsingPredicate:prdicate];
for (Products *item in newArray) {
NSLog(@"newArray=%@",item.productName);
}

2.查询数量大于9 并且productname等于“三星jfggg”的产品

//数量大于9 并且productname等于“三星jfggg” 定义谓词 包含过滤条件
prdicate=[NSPredicate predicateWithFormat:@"productName='三星' && productCount>9"];
//过滤结果返回新的数组
newArray=[sproducts filteredArrayUsingPredicate:prdicate];

3.in包含  (*注 包含是全字匹配)

prdicate = [NSPredicate predicateWithFormat:@"productName IN {'g','华为','三星'}||productCount IN {2,5}"];
//过滤结果返回新的数组
newArray=[sproducts filteredArrayUsingPredicate:prdicate];

4.字符串相关处理

//productName以a开头的
prdicate = [NSPredicate predicateWithFormat:@"productName BEGINSWITH 'A'"];
//productName以ba结尾的
prdicate = [NSPredicate predicateWithFormat:@"productName ENDSWITH 'g'"]; //name中包含字符a的
prdicate = [NSPredicate predicateWithFormat:@"productName CONTAINS 'a'"];

5.like通配符,用于模糊查询

 //like 匹配任意多个字符
//productName中只要有s字符就满足条件
prdicate = [NSPredicate predicateWithFormat:@"productName like '*s*'"];
//?代表一个字符,下面的查询条件是:name中第二个字符是s的
prdicate = [NSPredicate predicateWithFormat:@"productName like '?s*'"]; newArray=[sproducts filteredArrayUsingPredicate:prdicate];

6.正则表达式,例子是验证是否是手机号

//正则表达式串
NSString * MOBILE = @"^1(3[0-9]|5[0-35-9]|8[025-9])\\d{8}$";
//创建含有正则表达式的帅选器
NSPredicate *regextestmobile = [NSPredicate predicateWithFormat:@"SELF MATCHES %@", MOBILE];
//筛选器的evaluateWithObject方法反向验证是否手机号,返回bool值
BOOL isPhoneNum=[regextestmobile evaluateWithObject:@"15300250500"] ;

关于谓词的使用,我们只列举了几个常见的用法,它还有很多种灵活的用法,如对时间datetime的间隔筛选、谓词变量 ”谓词==$变量名“等,待有时间希望大家去研究。

转自:https://www.cnblogs.com/hj2xx2hj/p/4915159.html

NSPredicate谓词的用法的更多相关文章

  1. IOS开发之NSPredicate谓词的用法

    编程的人员不管是上过大学还是从培训机构出来的或做后台的.前端的都应该SQL语句有所了解,我们知道,在SQL语句当中 where 条件表达式可以对二维关系表的数据做条件筛选.微软的C# .net中也实现 ...

  2. objective-c中使用cocoa的NSPredicate,谓词(十四)

    holydancer原创,如需转载,请在显要位置注明: 转自holydancer的CSDN专栏,原文地址:http://blog.csdn.net/holydancer/article/details ...

  3. NSPredicate谓词

    NSPredicate——谓词(is) 作用:判断条件表达式的求值返回真或假的过程 使用步骤: . 定义NSPredicate对象并指定条件 . 调用谓词的evaluateWithObject方法判断 ...

  4. NSPredicate,谓词

    原文地址:http://blog.csdn.net/holydancer/article/details/7380799 在语言上,谓语,谓词是用来判断的,比如“我是程序猿”中的是,就是表判断的谓语, ...

  5. NSPredicate 谓词总结 数组过滤 模糊匹配

    NSPredicate 用于指定过滤条件,主要用于从集合中分拣出符合条件的对象,也可以用于字符串的正则匹配. NSPredicate常用方法介绍 1.创建NSPredicate(相当于创建一个过滤条件 ...

  6. NSPredicate谓词查询

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

  7. SQL进阶系列之8EXISTS谓词的用法

    写在前面 支撑SQL和关系数据库的基础理论:数学领域的集合论和逻辑学标准体系的谓词逻辑 理论篇 什么是谓词?谓词是返回值为真值(true false unknown)的函数 关系数据库里,每一个行数据 ...

  8. iOS数组使用

    相关链接: ios数组基本用法和排序 NSArray 排序汇总 iOS 数组排序方法 IOS-筛选数组内的元素 关于EnumerateObjectsUsingBlock和for-in之间的较量 [iO ...

  9. iOS中的谓词(NSPredicate)使用

    http://www.cocoachina.com/ios/20160111/14926.html 首先,我们需要知道何谓谓词,让我们看看官方的解释: The NSPredicate class is ...

随机推荐

  1. C# 读取本地图片

    /// <summary> /// 通过FileStream 来打开文件,这样就可以实现不锁定Image文件,到时可以让多用户同时访问Image文件 /// </summary> ...

  2. 【原创】大叔经验分享(78)hive查询报错NoViableAltException

    Hive或spark中执行sql字符常量包含;时会报错,比如 select instr('abc;abc', ';'); 报错 NoViableAltException(-1@[147:1: sele ...

  3. Python应用范围seo

    Python有许多OOP概念,包括类.对象.数据和方法.抽象.封装.继承和多态性等原则也可以使用Python实现和表示.python有几个高级函数,包括迭代器.生成器.列表分析器.lambda表达式和 ...

  4. Spring Boot启动流程分析

    引言 早在15年的时候就开始用spring boot进行开发了,然而一直就只是用用,并没有深入去了解spring boot是以什么原理怎样工作的,说来也惭愧.今天让我们从spring boot启动开始 ...

  5. 013.子查询和分页子查询(sql实例)

    --1 子查询 如果子查询和表连接都实现的时候,推荐用表连接实现( 一般:能用表连接实现的就用表连接,有些情况用表连接不能 或者不易实现的再选择子查询) 系统:缓存,执行计划技术手段 --1 wher ...

  6. Linux的.a、.so和.o文件及链接时的命名

    在说明Linux的.a..so和.o文件关系之前,先来看看windows下obj,lib,dll,exe的关系 windows下obj,lib,dll,exe的关系 lib是和dll对应的.lib是静 ...

  7. WebRTC基于GCC的拥塞控制算法[转载]

    实时流媒体应用的最大特点是实时性,而延迟是实时性的最大敌人.从媒体收发端来讲,媒体数据的处理速度是造成延迟的重要原因:而从传输角度来讲,网络拥塞则是造成延迟的最主要原因.网络拥塞可能造成数据包丢失,也 ...

  8. [MySQL优化] -- 如何查找SQL效率地下的原因

    [MySQL优化] -- 如何查找SQL效率地下的原因   来源: ChinaUnix博客 日期: 2009.07.20 16:12 (共有条评论) 我要评论       查询到效率低的 SQL 语句 ...

  9. Python3-for-enumerate

    languages = ["C", "C++", "Perl", "Python"] for x in language ...

  10. C# 通过Process.Start() 打开程序 置顶方法

    private void webBrowser1_Navigating(object sender, WebBrowserNavigatingEventArgs e) { try { foreach ...