1.基本:
>程序开发中需要查找符合某些复杂规则的字符串的需求。正则表达式就是用于描述这些规则的工具。即正则表达式就是记录文本规则的代码!
是对字符串操作的一种逻辑公式,用实现定义好饿一些特定字符、及这些特定字符的组合,组成一个"规则字符串",形成一种过滤逻辑。
Xcode支持正则表达式 OC,JAVA,C#,PYTHON等都支持
2.用法:
> 判断给定的字符串是否符合某一种规则【用于操作字符串】
> 过滤筛选字符,网络爬虫
> 替换位子、QQ聊天,图文混排
3.常用符号
> 集合
[xyz] 字符集合 // 只要匹配到x或y或z即可
[a-z] 字符范围 // 只要是小写字母a~z即可
[a-zA-Z] 字符范围 // 只要是英文字母即可
[^xyz] 负值字符集合 // 除了xyz,任何字符都可以
[^a-z] 负值字符范围 // 负值字符范围
[a-d][m-p] 并集 // a到d或m到p即可
> 元字符
. 匹配除换行符意外的任意字符
\w 匹配字母或数字或下划线或汉字[a-zA-Z_0-9]
\s 匹配任意的空白符(空格、TAB\t、回车\r \n)
\d 匹配数字[0-9]
^ 匹配字符串的开始
$ 匹配字符串的结束
\b 匹配单词的开始或结束
> 反义符
\W 匹配任意不是字母、数字、下划线、汉字的字符[^\w]
\S 匹配任意不是空白符的字符[^\s]
\D 匹配任意费数字的字符[^0-9]
\B 匹配不是单词开头或结束的位置
[^x] 匹配除了x以外的任意字符
[^aeiou] 匹配除了aeiou这几个字母以外的任意字符
> 限定符
* 重复零次或更多次
+ 重复一次或更多次
? 重复零次或一次
{n} 重复n次
{n,} 重复n次或更多次
{n, m} 重复n次到m次
> 贪婪和懒惰
*? 重复任意次,但尽可能少重复
*+ 重复1次或更多次,但尽可能少重复
?? 重复0次或1次,但尽可能少重复
{n, m}? 重复n到m次,但尽可能少重复
{n,}? 重复n次以上,但尽可能少重复