1.示例
NSString *string = @"35g677u88";
NSString *pattern = @"[a-zA-Z]";
NSRegularExpression *regex = [[NSRegularExpression alloc] initWithPattern:pattern options:0 error:nil];
NSArray *results = [regex matchesInString:string options:0 range:NSMakeRange(0, string.length)];
if (results.count = 0) {
NSLog(@"不包含字母");
} else {
NSLog(@"包含了字母");
}
正则表达式语法:
正则表达式是一种文本模式,包括普通字符(例如,a 到 z 之间的字母)和特殊字符(称为“元字符”)。模式描述在搜索文本时要匹配的一个或多个字符串。
1.例子:
表格
表达式 | 说明 |
---|---|
/^\s*$/ | 匹配空格 |
/\d{2}-\d{5}/ | 验证由两位数字、一个连字符再加 5 位数字组成的 ID 号 |
/<\s(\S+)(\s{FNXX==XXFN})?>[\s\S]<\s/\1\s*>/ | 匹配 HTML 标记 |
2.常用字符以及他们的作用
- 元字符
字符 | 说明 |
---|---|
. | 匹配除换行符以外的任意字符 |
\s | 匹配任意的空白符 |
\w | 匹配字母或数字或下划线或汉字 |
\d | 匹配数字 |
\b | 匹配单词的开始或结束 |
^ | 匹配字符串的开始 |
$ | 匹配字符串的结束 |
- 重复
字符 | 说明 |
---|---|
* | 重复零次或更多次 |
+ | 重复一次或更多次 |
? | 重复零次或一次 |
{n} | 重复n次 |
{n,} | 重复n次或更多次 |
{n,m} | 重复n到m次 |
- 字符
字符 | 说明 |
---|---|
[] | 在某个位置匹配方括号里的任意一个字符 |
[a-z] | 在某个位置匹配某个范围的字符 |
按位或字符 | 分支,即“或者” |
() | 括号,用于分组,括号中属于一个整体 |
- 反义字符
字符 | 说明 |
---|---|
\S | 匹配任意不是空白符的字符 |
\W | 匹配任意不是字母,数字,下划线,汉字的字符 |
\D | 匹配任意非数字的字符 |
\B | 匹配不是单词开头或结束的位置 |
[^a] | 匹配除了a以外的任意字符 |
[^abcdef] | 匹配除了abcdef这几个字母以外的任意字符 |
- 贪婪与懒惰
贪婪:
当正则表达式中包含能接受重复的限定符时,默认是匹配尽可能多的字符。
例如:a.*b,它将会匹配最长的以a开始,以b结束的字符串。如果用它来搜索aabab的话,它会匹配整个字符串aabab。这被称为贪婪匹配。
懒惰:
懒惰匹配,也就是匹配尽可能少的字符。只要在重复字符后面加上一个问号‘?’,就意味着匹配任意数量的重复,但是在能使整个匹配成功的前提下使用最少的重复。
例如:a.*?b,它将匹配最短的以a开始,以b结束的字符串。如果把它应用于aabab的话,它会匹配aab(第一到第三个字符)和ab(第四到第五个字符)。
声明:
以上内容属于本人整理的笔记,如有错误的地方希望能告诉我,大家共同进步。
以上内容有些段落或语句可能是本人从其他地方Copy而来,如有侵权,请及时告诉我。
网友评论