正则表达式
在编写处理字符串的程序时,经常会有查找符合某些复杂规则的字符串的需要。正则表达式就是用于描述这些规则的工具。换句话说,正则表达式就是记录文本规则的代码
正则表达式是对字符串操作的一种逻辑公式,用事先定义好的一些特定字符、及这些特定字符的组合,组成一个"规则字符串",这个"规则字符串"用来表达对字符串的一种过滤逻辑。
-在很多文本编辑器里,可以使用正则表达式进行检索,Xcode同样支持正则表达式!
-几乎所有的程序设计语言都支持正则表达式,例如:OC,java,c#,python,js等。练习:
练习1:匹配abc 练习2:包含一个写a~z,后面必须是0~9 -->[a-z][0-9]或者[a-z]\d 练习3:必须第一个是字母,第二个是数字 -->^[a-z][0-9]$ 练习4:必须第一个是字母,字母后面跟上4~9个数字 练习5:不能是数字[^0-9]练习6:QQ匹配:^[1-9]\d{4,11}$
1.都是数字 2.5~12位练习7:手机号码匹配^1[3578]\d{9}$
1.以13/15/17/18 2.长度是11常用正则表达式:
NSRegularExpressionCaseInsensitive = 1 << 0, 忽略大小写
NSRegularExpressionAllowCommentsAndWhitespace = 1 << 1, 忽略空白字符,以及前缀是 # 开始的注释 NSRegularExpressionIgnoreMetacharacters = 1 << 2, 将整个匹配方案作为文字字符串 NSRegularExpressionDotMatchesLineSeparators = 1 << 3, 允许 . 匹配任意字符,包括回车换行 NSRegularExpressionAnchorsMatchLines = 1 << 4, 允许 ^ 和 $ 匹配多行文本的开始和结尾 NSRegularExpressionUseUnixLineSeparators = 1 << 5, 仅将 \n 作为换行符 NSRegularExpressionUseUnicodeWordBoundaries = 1 << 6 使用 Unicode TR#29 指定单词边界url正则:"http(s)?://([\w-]+\.)+[\w-]+(/[\w- ./?%&=]*)?"
0> 匹配
(pattern) 匹配pattern并获取这一匹配,所获取的匹配可以从产生的Matches集合得到
1> 常用元字符
. 匹配除换行符以外的任意字符
\w 匹配字母或数字或下划线或汉字 \s 匹配任意的空白符(空格、TAB\t、回车\r \n) \d 匹配数字^ 匹配字符串的开始
$ 匹配字符串的结束 \b 匹配单词的开始或结束2> 常用反义符
\W 匹配任意不是字母,数字,下划线,汉字的字符
\S 匹配任意不是空白符的字符 \D 匹配任意非数字的字符\B 匹配不是单词开头或结束的位置
[^x] 匹配除了x以外的任意字符 [^aeiou] 匹配除了aeiou这几个字母以外的任意字符3> 集合
[xyz] 字符集合
[^xyz] 负值字符集合 [a-z] 字符范围 [^a-z] 负值字符范围4> 常用限定符
重复零次或更多次
重复一次或更多次
? 重复零次或一次 {n} 重复n次 {n,} 重复n次或更多次 {n,m} 重复n到m次
5> 贪婪和懒惰
? 重复任意次,但尽可能少重复+ 重复1次或更多次,但尽可能少重复
?? 重复0次或1次,但尽可能少重复 {n,m}? 重复n到m次,但尽可能少重复 {n,}? 重复n次以上,但尽可能少重复