⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 zhengzebiaodashi.txt

📁 正则表达式(regular expression)使用大全
💻 TXT
📖 第 1 页 / 共 5 页
字号:


  如果,要匹配包括"\n"在内的所有单个字符,怎么办?
  对了,用'[\n.]'这种模式.

  "a.[0-9]": 一个a加一个字符再加一个0到9的数字 
  "^.{3}$": 三个任意字符结尾 . 

  中括号括住的内容只匹配一个单一的字符 

  "[ab]": 匹配单个的 a 或者 b ( 和 "a│b" 一样); 
  "[a-d]": 匹配'a' 到'd'的单个字符 (和"a│b│c│d" 还有 "[abcd]"效果一样); 一般我们都用[a-zA-Z]来指定字符为一个大小写英文
  "^[a-zA-Z]": 匹配以大小写字母开头的字符串 
  "[0-9]%": 匹配含有 形如 x% 的字符串 
  ",[a-zA-Z0-9]$": 匹配以逗号再加一个数字或字母结尾的字符串 

  你也可以把你不想要得字符列在中括号里,你只需要在总括号里面使用'^' 作为开头 "%[^a-zA-Z]%" 匹配含有两个百分号里面有一个非字母的字符串. 

要点:^用在中括号开头的时候,就表示排除括号里的字符

为了PHP能够解释,你必须在这些字符面前后加'',并且将一些字符转义. 

 

  不要忘记在中括号里面的字符是这条规路的例外—在中括号里面, 所有的特殊字符,包括(''), 都将失去他们的特殊性质 "[*\+?{}.]"匹配含有这些字符的字符串. 
 

  还有,正如regx的手册告诉我们: "如果列表里含有 ']', 最好把它作为列表里的第一个字符(可能跟在'^'后面). 如果含有'-', 最好把它放在最前面或者最后面, or 或者一个范围的第二个结束点[a-d-0-9]中间的‘-’将有效. 
 

  看了上面的例子,你对{n,m}应该理解了吧.要注意的是,n和m都不能为负整数,而且n总是小于m. 这样,才能 最少匹配n次且最多匹配m次. 如"p{1,5}"将匹配 "pvpppppp"中的前五个p 
 

  下面说说以\开头的 
 

  \b 书上说他是用来匹配一个单词边界,就是...比如've\b',可以匹配love里的ve而不匹配very里有ve 
 

  \B 正好和上面的\b相反.例子我就不举了 
 

  好,我们来做个应用:

如何构建一个模式来匹配 货币数量 的输入


  构建一个匹配模式去检查输入的信息是否为一个表示money的数字。我们认为一个表示money的数量有四种方式: "10000.00" 和 "10,000.00",或者没有小数部分, "10000" and "10,000". 现在让我们开始构建这个匹配模式: 

 

  ^[1-9][0-9]*$ 

 

  这是所变量必须以非0的数字开头.但这也意味着 单一的 "0" 也不能通过测试. 以下是解决的方法: 
  ^(0│[1-9][0-9]*)$ 

 

  "只有0和不以0开头的数字与之匹配",我们也可以允许一个负号在数字之前: 
  ^(0│-?[1-9][0-9]*)$ 

 

  这就是: "0 或者 一个以0开头 且可能 有一个负号在前面的数字." 好了,现在让我们别那么严谨,允许以0开头.现在让我们放弃负号 , 因为我们在表示钱币的时候并不需要用到. 我们现在指定 模式 用来匹配小数部分: 
  ^[0-9]+(\.[0-9]+)?$ 

 

这暗示匹配的字符串必须最少以一个阿拉伯数字开头. 但是注意,在上面模式中 "10." 是不匹配的, 只有 "10" 和 "10.2" 才可以. (你知道为什么吗) 

 

  ^[0-9]+(\.[0-9]{2})?$ 

 

  我们上面指定小数点后面必须有两位小数.如果你认为这样太苛刻,你可以改成: 
  ^[0-9]+(\.[0-9]{1,2})?$ 

 

  这将允许小数点后面有一到两个字符. 现在我们加上用来增加可读性的逗号(每隔三位), 我们可以这样表示: 
  ^[0-9]{1,3}(,[0-9]{3})*(\.[0-9]{1,2})?$ 

 

  不要忘记 '+' 可以被 '*' 替代 如果你想允许空白字符串被输入话 (为什么?). 也不要忘记反斜杆 ’\’ 在php字符串中可能会出现错误 (很普遍的错误). 

  现在,我们已经可以确认字符串了, 我们现在把所有逗号都去掉 str_replace(",", "", $money) 然后在把类型看成 double然后我们就可以通过他做数学计算了. 

构造检查email的正则表达式


  在一个完整的email地址中有三个部分: 
  1. 用户名 (在 '@' 左边的一切), 
  2.'@',
  3. 服务器名(就是剩下那部分). 
  用户名可以含有大小写字母阿拉伯数字,句号 ('.'), 减号('-'), and 下划线 ('_'). 服务器名字也是符合这个规则,当然下划线除外. 

  现在, 用户名的开始和结束都不能是句点. 服务器也是这样. 还有你不能有两个连续的句点他们之间至少存在一个字符,好现在我们来看一下怎么为用户名写一个匹配模式: 

  ^[_a-zA-Z0-9-]+$ 

 

  现在还不能允许句号的存在. 我们把它加上: 
  ^[_a-zA-Z0-9-]+(\.[_a-zA-Z0-9-]+)*$ 

 

  上面的意思就是说: "以至少一个规范字符(除了.)开头,后面跟着0个或者多个以点开始的字符串." 

 

简单化一点, 我们可以用 eregi()取代 ereg().eregi()对大小写不敏感, 我们就不需要指定两个范围 "a-z" 和 "A-Z" – 只需要指定一个就可以了: 
  ^[_a-z0-9-]+(\.[_a-z0-9-]+)*$ 

 

  后面的服务器名字也是一样,但要去掉下划线: 
  ^[a-z0-9-]+(\.[a-z0-9-]+)*$ 

 

  好. 现在只需要用”@”把两部分连接: 
  ^[_a-z0-9-]+(\.[_a-z0-9-]+)*@[a-z0-9-]+(\.[a-z0-9-]+)*$ 

  这就是完整的email认证匹配模式了,只需要调用 
  eregi(‘^[_a-z0-9-]+(\.[_a-z0-9-]+)*@[a-z0-9-]+(\.[a-z0-9-]+)*$ ’,$eamil) 
  就可以得到是否为email了 

 

  正则表达式的其他用法 

 

  提取字符串 
  ereg() and eregi() 有一个特性是允许用户通过正则表达式去提取字符串的一部分,比如说,我们想从 path/URL 提取文件名 – 下面的代码就是你需要: 
  ereg("([^\\/]*)$", $pathOrUrl, $regs); 
  echo $regs[1]; 

 

  高级的代换 
  ereg_replace() 和 eregi_replace()也是非常有用的: 假如我们想把所有的间隔负号都替换成逗号: 
  ereg_replace("[ \n\r\t]+", ",", trim($str)); 

 

  最后,我把另一串检查EMAIL的正则表达式让看文章的你来分析一下.
  "^[-!#$%&\'*+\\./0-9=?A-Z^_`a-z{|}~]+'.'@'.'[-!#$%&\'*+\\/0-9=?A-Z^_`a-z{|}~]+\.'.'[-!#$%&\'*+\\./0-9=?A-Z^_`a-z{|}~]+$"




发表于 @ 2006年04月24日 10:30 PM | 评论 (0)


正则表达式几种常用功能——查询,提取,替换,分割


正则表达式在字符串处理上有着强大的功能,sun在jdk1.4加入了对它的支持 

下面简单的说下它的4种常用功能:

查询:

String str="abc efg ABC";

String regEx="a|f";   //表示a或f 

Pattern p=Pattern.compile(regEx);

Matcher m=p.matcher(str);

boolean rs=m.find();

如果str中有regEx,那么rs为true,否则为flase。如果想在查找时忽略大小写,则可以写成Pattern p=Pattern.compile(regEx,Pattern.CASE_INSENSITIVE);

提取:

String regEx=".+\\\\(.+)$";

String str="c:\\dir1\\dir2\\name.txt";

Pattern p=Pattern.compile(regEx);

Matcher m=p.matcher(str);

boolean rs=m.find();

for(int i=1;i<=m.groupCount();i++){

System.out.println(m.group(i));

}

以上的执行结果为name.txt,提取的字符串储存在m.group(i)中,其中i最大值为m.groupCount();

分割:

String regEx="::";

Pattern p=Pattern.compile(regEx);

String[] r=p.split("xd::abc::cde");

执行后,r就是{"xd","abc","cde"},其实分割时还有跟简单的方法:

String str="xd::abc::cde";

String[] r=str.split("::");

替换(删除):

String regEx="a+"; //表示一个或多个a

Pattern p=Pattern.compile(regEx);

Matcher m=p.matcher("aaabbced a ccdeaa");

String s=m.replaceAll("A");

结果为"Abbced A ccdeA"

如果写成空串,既可达到删除的功能,比如:

String s=m.replaceAll("");

结果为"bbced  ccde"

 




正则表达式


正则表达式 By  xmseo 发表于 2006-4-9 12:56:28  


 [java]J***A正则表达式 
□javaonline 发表于 2006-2-20 19:12:00 
J***A正则表达式关键词: 正则表达式                                           

正则表达式作为本章的结尾,我们来看一看正则表达式(regular expression)。正则表达式是JDK 1.4的新功能,但是对sed和awk这样的Unix的标准实用工具,以及Python,Perl之类的语言来讲,它早就已经成为其不可或缺的组成部分了 (有人甚至认为,它还是Perl能大获成功的最主要的原因)。单从技术角度来讲,正则表达式只是一种处理字符串的工具(过去Java这个任务是交由 String,StringBuffer以及StringTokenizer处理的),但是它常常和I/O一起使用,所以放到这里来讲也不算太离题吧。 [66]

正则表达式是一种功能强大但又非常灵活的文本处理工具。它能让你用编程的方式来描述复杂的文本模式,然后在字符串里把它找出来。一旦你找到了这种模式,你就能随心所欲地处理这些文本了。虽然初看起来正则表达式的语法有点让人望而生畏,但它提供了一种精练的动态语言,使我们能用一种通用的方式来解决各种字符串的问题,包括匹配,选择,编辑以及校验。

创建正则表达式
你可以从比较简单的东西入手学习正则表达式。要想全面地掌握怎样构建正则表达式,可以去看JDK文档的java.util.regex的Pattern类的文档。

字符 
B 字符B 
\xhh 16进制值0xhh所表示的字符 
\uhhhh 16进制值0xhhhh所表示的Unicode字符 
\t Tab 
\n 换行符 
\r 回车符 
\f 换页符 
\e Escape 

正则表达式的强大体现在它能定义字符集(character class)。下面是一些最常见的字符集及其定义的方式,此外还有一些预定义的字符集:

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -