正则表达式
-
在编写处理字符串的程序时,经常会有查找符合某些复杂规则的字符串的需要。正则表达式就是用于描述这些规则的工具。换句话说,正则表达式就是记录文本规则的代码
-
正则表达式是对字符串操作的一种逻辑公式,用事先定义好的一些特定字符、及这些特定字符的组合,组成一个"规则字符串",这个"规则字符串"用来表达对字符串的一种过滤逻辑。
-
在很多文本编辑器里,可以使用正则表达式进行检索,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
常用正则表达式:http://www.cnblogs.com/zxin/archive/2013/01/26/2877765.html
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- ./?%&=]*)?"
- 匹配
(pattern):匹配pattern并获取这一匹配,所获取的匹配可以从产生的Matches集合得到
- 常用元字符
. 匹配除换行符以外的任意字符
\w 匹配字母或数字或下划线或汉字
\s 匹配任意的空白符(空格、TAB\t、回车\r \n)
\d 匹配数字
^ 匹配字符串的开始
$ 匹配字符串的结束
\b 匹配单词的开始或结束
- 常用反义符
\W 匹配任意不是字母,数字,下划线,汉字的字符
\S 匹配任意不是空白符的字符
\D 匹配任意非数字的字符
\B 匹配不是单词开头或结束的位置
[^x] 匹配除了x以外的任意字符
[^aeiou] 匹配除了aeiou这几个字母以外的任意字符
- 集合
[xyz] 字符集合
[^xyz] 负值字符集合
[a-z] 字符范围
[^a-z] 负值字符范围
- 常用限定符
* 重复零次或更多次
+ 重复一次或更多次
? 重复零次或一次
{n} 重复n次
{n,} 重复n次或更多次
{n,m} 重复n到m次
- 其他
*? 重复任意次,但尽可能少重复
*+ 重复1次或更多次,但尽可能少重复
?? 重复0次或1次,但尽可能少重复
{n,m}? 重复n到m次,但尽可能少重复
{n,}? 重复n次以上,但尽可能少重复
网友评论