您的位置:首页 > 移动开发 > IOS开发

iOS NSRegularExpression 正则表达式的编写和使用

2017-10-14 20:11 387 查看
简述

NSPredicate 校验方法

NSRegularExpression 的使用
1初始化
NSRegularExpressionOptions

2调用方法
NSMatchingOptions

NSMatchingFlags

正则表达式编写手册

过滤字符
开头长度
乘法集

通配符号和 判断符号

和 以某字符开头或结束

区间符号 -
或符号

方括号

匹配除rn之外的任何单个字符

过滤数字
长度相关

小数

汉字

过滤组合

参考资料

简述

在开发过程中,我们经常需要校验邮箱、手机号等,这个时候就需要用到正则表达式。

正则表达式 是一个字符串,可以用来简化检索、替换特定的字符串,

在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]是一样的。

@”^[A-Za-z]+$”;//由26个英文字母组成的字符串;

@”^[A-Z]+$”; //由26个大写英文字母组成的字符串;

@”^[a-z]+$”;//由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。

过滤数字

符号的使用,和字符串中一致,可参考上面内容 ��。

@”^[0-9]*$”;//纯数字 ,如 @“0755”,@“0”;不包含:@“1abc”,@”hha2”。

@”\\d”;//记得是2个
\
,其中一个是转义。单个数字字符,如 0,1。不包含:01,10,123,a。

@”\\D”;//记得是2个
\
。单个非数字字符,如a,b。不包含 ab,1,2,123。

长度相关

@”\d{3}”;//3位数字,如123,000。如果确定为n位的话,3改为 n 即可。

@”\d{3,}”;//至少3位数字,如123,000,1111。不含:12,0。

@”\d{2,4}”;//2-4位纯数字,如 12,123,1234。不含0,1a,12345。

@”(.)1”;//长度为2的字符串,第二个字符为 1。如:a1,b1,11,21。不含:1a,12。

@”10{1,3}”;//数字1后面跟着1-3个0,如 10,100,1000。不含:1,10000。

@”0{2,}”;//数字为至少2个连续的0,如00,00,000。不含 0,01。

@”\^0*”;//0开头,长度任意的数字字符串。如0,01,000,0000。不含:0a,10.

小数

@”[0-9]+(.[0-9]{2})”;//只能输入有两位小数的正实数,如 1.22,22.11。不含:1.2,a.12。

汉字

@”^[\u4e00-\u9fa5]{0,}$”;//0位及以上的汉字,如:”“(空字符串),哈哈,嗯嗯恩。不含:哈2,2恩。

过滤组合

@”[0-9]a”; //表示a前有一位的数字

@”[0-9][0-9]a”; //表示a前有2位的数字

@”\w” //匹配包括下划线的任何单词字符。等价于
[A-Za-z0-9_]
。如

@”\W” //匹配任何非单词字符。等价于
[^A-Za-z0-9_]


参考资料

珲少:分分钟使用正则表达式

https://my.oschina.net/u/2340880/blog/403508

珲少:iOS中正则表达式的使用

http://my.oschina.net/u/2340880/blog/403638
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: