就我知道的,在OC中使用正则表达式有三种方式
字符串配置options NSRegularExpressionSearch
谓词匹配NSPredicate(SELF MATCHES 表达式)
NSRegularExpression类
方式一 字符串option
NSString *str = @"MessageMe";
//找到正则表达式匹配的第一个字符串rangge
NSRange range = [str rangeOfString:@"(a|m|i)" options:NSRegularExpressionSearch];
//找到正则表达式匹配的字符串 并替换
NSString *replacStr = [str stringByReplacingOccurrencesOfString:@"^[A-Z]e" withString:@"mE" options:NSRegularExpressionSearch range:NSMakeRange(0, str.length)];//mEssageMe
//返回值 表示有几处被替换了
NSInteger replaceCount = [[NSMutableString stringWithString:str] replaceOccurrencesOfString:@"[A-z]e" withString:@"HH" options:NSRegularExpressionSearch range:NSMakeRange(0, str.length)];//HHssaHHHH
NSLog(@"range:%@-replacStr:%@-replaceCount:%zd",NSStringFromRange(range),replacStr,replaceCount);
方式二:谓词NSPredicate
NSString *str = @"message";
//@"^m[a-z]+" 以m开头 多个小写字母跟在后面
NSPredicate *pre = [NSPredicate predicateWithFormat:@"SELF MATCHES %@",@"^m[a-z]+"];
//进行匹配
BOOL result = [pre evaluateWithObject:str];
NSLog(@"%@",result ? @"YES" : @"NO");
方式三:NSRegularExpression类
NSString *str = @"message";
NSRegularExpression *re = [NSRegularExpression regularExpressionWithPattern:@"[a-z]e" options:NSRegularExpressionUseUnixLineSeparators error:nil];
//获取所有满足表达式的字符串
NSMutableArray *matchS = [NSMutableArray array];
[re enumerateMatchesInString:str options:0 range:NSMakeRange(0, str.length) usingBlock:^(NSTextCheckingResult * _Nullable result, NSMatchingFlags flags, BOOL * _Nonnull stop) {
for (int i = 0; i < result.numberOfRanges; i ++) {
[matchS addObject:[str substringWithRange:[result rangeAtIndex:i]]];
}
}];
NSLog(@"%@",matchS);
//获取所有满足表达式的字符串
[matchS removeAllObjects];
NSArray <NSTextCheckingResult *>*chectRS = [re matchesInString:str options:0 range:NSMakeRange(0, str.length)];
for (NSTextCheckingResult *result in chectRS) {
for (int i = 0; i < result.numberOfRanges; i ++) {
[matchS addObject:[str substringWithRange:[result rangeAtIndex:i]]];
}
}
NSLog(@"%@",matchS);
/*
NSRegularExpressionCaseInsensitive= 1 << 0, /*不区分大小写* /
NSRegularExpressionAllowCommentsAndWhitespace = 1 << 1, /*忽略空格和# -* /
NSRegularExpressionIgnoreMetacharacters = 1 << 2, /*整体化* /
NSRegularExpressionDotMatchesLineSeparators = 1 << 3, /*允许。匹配任何字符,包括行分隔符。* /
nsregularexpressionsmatchline = 1 << 4, /* 允许^和$在匹配的开始和结束行 * /
NSRegularExpressionUseUnixLineSeparators = 1 << 5, /*只处理\n作为行分隔符(否则,使用所有标准行分隔符)。* /
NSRegularExpressionUseUnicodeWordBoundaries = 1 << 6 /*使用Unicode TR#29来指定单词边界(否则,使用传统的正则表达式单词边界)。* /
**/
/*
针对这个方法起作用:enumerateMatchesInString:options:range:usingBlock:
NSMatchingReportProgress = 1 << 0, // 在长时间匹配操作期间定期调用阻止
NSMatchingReportCompletion = 1 << 1, // 任何匹配完成后调用一次Block
NSMatchingAnchored = 1 << 2, // 指定匹配仅限于搜索范围开始处的匹配
NSMatchingWithTransparentBounds = 1 << 3, // 指定匹配可以检查超出搜索范围边界的字符串部分,以用于诸如字边界检测,预测等。如果搜索范围包含整个字符串,则该常量不起作用
NSMatchingWithoutAnchoringBounds = 1 << 4 // 指定^并$不会自动匹配搜索范围的开始和结束,但仍将匹配整个字符串的开头和结尾。如果搜索范围包含整个字符串,则该常量不起作用
**/
/*
NSMatchingProgress = 1 << 0, //匹配进度
NSMatchingCompleted = 1 << 1, //完成匹配
NSMatchingHitEnd = 1 << 2, //当前的匹配操作到达搜索范围的末尾
NSMatchingRequiredEnd = 1 << 3, //当前匹配依赖于搜索范围的结束位置
NSMatchingInternalError = 1 << 4 //由于内部错误,匹配失败时
**/
//注意:这里只展示了两个方法的调用 这两个方法都可以匹配出所有符合的字符串 另外还有很多其它的方法可以调用 可以进入查看
关于正则的一个工程:https://github.com/DeepSeaGhost/RegularExpressionsTest