Oc 正则表达式~常用符号

来源:互联网 发布:蓝牙gps连接软件 编辑:程序博客网 时间:2024/06/07 20:15

正则表达式

在编写处理字符串的程序时,经常会有查找符合某些复杂规则的字符串的需要。正则表达式就是用于描述这些规则的工具。换句话说,正则表达式就是记录文本规则的代码

正则表达式是对字符串操作的一种逻辑公式,用事先定义好的一些特定字符、及这些特定字符的组合,组成一个”规则字符串”,这个”规则字符串”用来表达对字符串的一种过滤逻辑。

-在很多文本编辑器里,可以使用正则表达式进行检索,Xcode同样支持正则表达式!
-几乎所有的程序设计语言都支持正则表达式,例如:OC,Java,c#,Python,js等。

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次以上,但尽可能少重复

原创粉丝点击