文章目录
简述
在开发过程中,我们经常需要校验邮箱、手机号等,这个时候就需要用到正则表达式。
正则表达式 是一个字符串,可以用来简化检索、替换特定的字符串,
在iOS开发中,能用来做正则校验的有两个 NSPredicate 和 NSRegularExpression 。
NSPredicate 能用来简单做正则校验,但是它的问题是存在校验不出来的情况。
NSPredicate 校验方法
编写正则表达式,然后配合 NSPredicate 中的Matches 字符。
更多 NSPredicate 方法(过滤数字、字符串、数组),可参考文章:http://blog.csdn.net/lovechris00/article/details/78227305
NSString *regex0 = @"^(0[0-9]{2,3})$";
NSPredicate *pred0 = [NSPredicate predicateWithFormat:@"SELF MATCHES %@", regex0];
NSLog(@"%d",[pred0 evaluateWithObject:@"0755"]);
NSRegularExpression 的使用
基本使用示例:
1、初始化
你可以使用类方法或示例方法初始化,作用一致
+ (NSRegularExpression *)regularExpressionWithPattern:(NSString *)pattern options:(NSRegularExpressionOptions)options error:(NSError **)error;
- (instancetype)initWithPattern:(NSString *)pattern options:(NSRegularExpressionOptions)options error:(NSError **)error
上述初始化中,options 为下面枚举值。你可以根据需要赋值。
NSRegularExpressionOptions
typedef NS_OPTIONS(NSUInteger, NSRegularExpressionOptions) {
NSRegularExpressionCaseInsensitive = 1 << 0, //不区分字母大小写的模式,aBc 会匹配到abc.
NSRegularExpressionAllowCommentsAndWhitespace = 1 << 1, //忽略掉正则表达式中的空格和#号之后的字符,表达式[a-z],会匹配到[a-z]
NSRegularExpressionIgnoreMetacharacters = 1 << 2, //将正则表达式整体作为字符串处理。表达式 a b c 会匹配到abc,ab#c会匹配到ab。
NSRegularExpressionDotMatchesLineSeparators = 1 << 3, //允许.匹配任何字符,包括换行符
NSRegularExpressionAnchorsMatchLines = 1 << 4, //允许^和$符号匹配行的开头和结尾
NSRegularExpressionUseUnixLineSeparators = 1 << 5, //设置\n为唯一的行分隔符,否则所有的都有效。
NSRegularExpressionUseUnicodeWordBoundaries = 1 << 6 //使用Unicode TR#29标准作为词的边界,否则所有传统正则表达式的词边界都有效
};
2、调用方法
- 返回一个结果数组,数组包含所有匹配的结果
- (NSArray *)matchesInString:(NSString *)string options:(NSMatchingOptions)options range:(NSRange)range;
- 返回匹配到得字符串的个数
- (NSUInteger)numberOfMatchesInString:(NSString *)string options:(NSMatchingOptions)options range:(NSRange)range;
- 返回第一个查询到得结果,这个 NSTextCheckingResult 对象中有一个range属性,可以得到匹配到的字符串的范围。
- (NSTextCheckingResult *)firstMatchInString:(NSString *)string options:(NSMatchingOptions)options range:(NSRange)range;
- 直接返回匹配到得范围,NSRange。
- (NSRange)rangeOfFirstMatchInString:(NSString *)string options:(NSMatchingOptions)options range:(NSRange)range;
- 带block模式的方法:
- (void)enumerateMatchesInString:(NSString *)string options:(NSMatchingOptions)options range:(NSRange)range usingBlock:(void (^)(NSTextCheckingResult *result, NSMatchingFlags flags, BOOL *stop))block;
其中 options 为设置回调的方式:
NSMatchingOptions
typedef NS_OPTIONS(NSUInteger, NSMatchingOptions) {
NSMatchingReportProgress = 1 << 0, //找到最长的匹配字符串后调用block回调
NSMatchingReportCompletion = 1 << 1, //找到任何一个匹配串后都回调一次block
NSMatchingAnchored = 1 << 2, //从匹配范围的开始出进行极限匹配
NSMatchingWithTransparentBounds = 1 << 3, //允许匹配的范围超出设置的范围
NSMatchingWithoutAnchoringBounds = 1 << 4 //禁止^和$自动匹配行还是和结束
};
flags 的值为下述枚举
NSMatchingFlags
typedef NS_OPTIONS(NSUInteger, NSMatchingFlags) {
NSMatchingProgress = 1 << 0, //匹配到最长串是被设置
NSMatchingCompleted = 1 << 1, //全部分配完成后被设置
NSMatchingHitEnd = 1 << 2, //匹配到设置范围的末尾时被设置
NSMatchingRequiredEnd = 1 << 3, //当前匹配到的字符串在匹配范围的末尾时被设置
NSMatchingInternalError= 1 << 4 //由于错误导致的匹配失败时被设置
};
正则表达式编写手册
过滤字符
开头&长度
@“ab?”; //表示一个字符串有一个a后面跟着0或者1个b,即 a, ab;不行: abb.abbb。
@“ab*”;//表示一个字符串有一个a后面跟着0或若干个b,如 a,ab,abbb,……)
@“ab+”;//表示一个字符串有一个a后面跟着1或若干个b,如 a,ab,abbb,……;不含 a。
乘法集 {}
@“ab{1,}”;//字符串中,a后面跟着至少一个 b,如 ab,abb,abbb;不行:a,abba,bab 。
注:可以没有下限,但是不能没有上限。例如 @“ab{,5}” 是错误的写法
@“ab{2}”;//表示一个字符串有一个a跟着2个b,即:abb。同理,跟着4个 b,则为 @“ab{4}”。
@“ab{3,4}”; //表示一个字符串有一个a,后面跟着3到4个b,即 abbb,abbbb。 同理如果包含5–10个b,则写为 @“ab{5,10}”;包含 0-2个b,写为 @“ab{0,2}”。
通配符号*
,+
和 判断符号 ?
综上示例,可以看出:*
可以用 {0,}
表示,
+
可以用 {1,}
表示,
?
可以用 {0,1}
表示。
这三个符号,表示一个或N个字符重复出现的次数:
[0,+∞] 没有或更多;
[1,+∞]一次或更多;
[0,1] 没有或一次。
^
和 `# 以某字符开头或结束
^
和 $
前面需要加上转义字符:\
,否则过滤失败,加上后可能会警告:unknown escape sequence
,但是可以运行成功。
@“^a”;// 单个字符:a。
@“^ab”;// 两个字符:ab。 不包含:abb。
@“^a.”;//两个字符,以 a 开头,如 a1,ab。
区间符号 -
注意:
- 1.区间的范围应该有意义,[a-1]这样的区间并无任何意义,尽管它在语法上可能没有错误。
- 2.区间左右两端对应的是字符,并不是数字,比如[2-41],这个式子的含义是找到2-4的一个数字或者1,和[1-4]是一样的。
@“1+$”;//由26个英文字母组成的字符串;
@“2+$”; //由26个大写英文字母组成的字符串;
@“3+$”;//由26个小写英文字母组成的字符串
或符号 |
@“a|b”; // 字符串里有 a 或有 b ;如 a,b。不行:ab,a1,b1,abb
@“(a|bc)de”;// 表示 ade 或 bcde。不行:abcde
方括号 [ ]
表示在括号内的众多字符中,选择1-N个括号内的符合语法的字符、长度为1的字符串。如:
@“[ab]”;//“:表示一个字符串有一个”a”或”b”(相当于”a|b”);如 a,b。不行:ab,a1,b1,abb。
@“[a-d]”;//字符串包含小写的’a’到’d’中的一个(相当于”a|b|c|d”或者”[abcd]“);即:a,b,c,d;不行:ab,abcd。
@“[a-zA-Z]”;//即:a,b,c,d…z;不行:ab,abcd。
.
匹配除“\r\n”之外的任何单个字符
@“a.[a-z]”;//字符串长度为3,首字母为a,中间为任意字符,最后是一个小写字母,如 abb,azb,a*b,a1b;不行:ab,abbb。
@“.{5}”;//长度为5的字符串,如 abcde,abbbb,a12bc。
过滤数字
符号的使用,和字符串中一致,可参考上面内容