正则表达式

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次以上,但尽可能少重复
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容