正则表达式学习笔记

原创 2003年09月09日 09:00:00

1、正则表达式的三种形式
首先我们应该知道 Perl 程序中,正则表达式有三种存在形式,他们分别是:

匹配:m/<regexp>/ (还可以简写为 /<regexp>/ ,略去 m)

替换:s/<pattern>/<replacement>/

转化:tr/<pattern>/<replacemnt>/

这三种形式一般都和 =~ 或 !~ 搭配使用(其中 "=~" 表示相匹配,在整条语句中读作 does,"!~" 表示不匹配,在整条语句中读作 doesn't),并在左侧有待处理的标量变量。如果没有该变量和 =~ !~ 操作符,则默认为处理 $_ 变量中的内容。
另外还有:

foreach (@array) { s/a/b/; } # 此处每次循环将从 @array 数组中取出一个元素存放在 $_ 变量中,并对 $_ 进行替换处理。
while (<FILE>) { print if (m/error/); } # 这一句稍微复杂一些,他将打印 FILE 文件中所有包含 error 字符串的行。

替换操作 s/<pattern>/<replacement>/ 还可以在末尾加上 e 或 g 参数,他们的含义分别为:

s/<pattern>/<replacement>/g 表示把待处理字符串中所有符合 <pattern> 的模式全部替换为 <replacement> 字符串,而不是只替换第一个出现的模式。
s/<pattern>/<replacement>/e 表示将把 <replacemnet> 部分当作一个运算符,这个参数用的不多。

2 正则表达式中的常用模式
下面是正则表达式中的一些常用模式。

/pattern/  结果 
. 匹配除换行符以外的所有字符
x? 匹配 0 次或一次 x 字符串
x* 匹配 0 次或多次 x 字符串,但匹配可能的最少次数
x+ 匹配 1 次或多次 x 字符串,但匹配可能的最少次数
.* 匹配 0 次或一次的任何字符
.+ 匹配 1 次或多次的任何字符
{m} 匹配刚好是 m 个 的指定字符串
{m,n} 匹配在 m个 以上 n个 以下 的指定字符串
{m,} 匹配 m个 以上 的指定字符串
[] 匹配符合 [] 内的字符
[^] 匹配不符合 [] 内的字符
[0-9] 匹配所有数字字符
[a-z] 匹配所有小写字母字符
[^0-9] 匹配所有非数字字符
[^a-z] 匹配所有非小写字母字符
^ 匹配字符开头的字符
$ 匹配字符结尾的字符
/d 匹配一个数字的字符,和 [0-9] 语法一样
/d+ 匹配多个数字字符串,和 [0-9]+ 语法一样
/D 非数字,其他同 /d
/D+ 非数字,其他同 /d+
/w 英文字母或数字的字符串,和 [a-zA-Z0-9] 语法一样
/w+ 和 [a-zA-Z0-9]+ 语法一样
/W 非英文字母或数字的字符串,和 [^a-zA-Z0-9] 语法一样
/W+ 和 [^a-zA-Z0-9]+ 语法一样
/s 空格,和 [/n/t/r/f] 语法一样
/s+ 和 [/n/t/r/f]+ 一样
/S 非空格,和 [^/n/t/r/f] 语法一样
/S+ 和 [^/n/t/r/f]+ 语法一样
/b 匹配以英文字母,数字为边界的字符串
/B 匹配不以英文字母,数值为边界的字符串
a|b|c 匹配符合a字符 或是b字符 或是c字符 的字符串
abc 匹配含有 abc 的字符串
(pattern) () 这个符号会记住所找寻到的字符串,是一个很实用的语法。第一个 () 内所找到的字符串变成 $1 这个变量或是 /1 变量,第二个 () 内所找到的字符串变成 $2 这个变量或是 /2 变量,以此类推下去。 
/pattern/i i 这个参数表示忽略英文大小写,也就是在匹配字符串的时候,不考虑英文的大小写问题。
/ 如果要在 pattern 模式中找寻一个特殊字符,如 "*",则要在这个字符前加上 / 符号,这样才会让特殊字符失效
3、正则表达式的八大原则
  如果在 Unix 中曾经使用过 sed、awk、grep 这些命令的话,相信对于正则表达式(Regular Expression)不会感到陌生。下面给大家介绍几条正则表达式使用过程中的 8 大原则。

正则表达式在对付数据的战斗中可形成庞大的联盟——这常常是一场战争。我们要记住下面八条原则:

· 原则1:正则表达式有三种不同形式(匹配(m/ /),替换(s/ / /eg)和转换(tr/ / /))。

· 原则2:正则表达式仅对标量进行匹配( $scalar =~ m/a/; 可以工作; @array =~ m/a/ 将把@array作为标量对待,因此可能不会成功)。

· 原则3:正则表达式匹配一个给定模式的最早的可能匹配。缺省时,仅匹配或替换正则表达式一次( $a = 'string string2'; $a =~ s/string/ /; 导致 $a = 'string 2')。

· 原则4:正则表达式能够处理双引号所能处理的任意和全部字符( $a =~ m/$varb/ 在匹配前把varb扩展为变量;如果 $varb = 'a' $a = 'as',$a =~ s/$varb/ /; 等价于 $a =~ s/a/ /; ,执行结果使 $a = " s" )。

· 原则5:正则表达式在求值过程中产生两种情况:结果状态和反向引用: $a=~ m/pattern/ 表示 $a 中是否有子串 pattern 出现,$a =~ s/(word1)(word2)/$2$1/ 则“调换”这两个单词。

· 原则6:正则表达式的核心能力在于通配符和多重匹配运算符以及它们如何操作。$a =~ m//w+/ 匹配一个或多个单词字符;$a =~ m//d/" 匹配零个或多个数字。

· 原则7:如果欲匹配不止一个字符集合,Perl使用 "|" 来增加灵活性。如果输入 m/(cat|dog)/ 则相当于“匹配字符串 cat 或者 dog。

· 原则8:Perl用 (?..) 语法给正则表达式提供扩展功能。

(想要学习所有这些原则?我建议大家先从简单的开始,并且不断的尝试和实验。

正则表达式学习笔记(二)——简单的正则表达式

一、简单的正则表达式
  • u011468424
  • u011468424
  • 2016年08月10日 15:19
  • 162

正则表达式学习笔记(全)

《正则表达式必知必会》Ben Forta著---学习笔记
  • yuhk231
  • yuhk231
  • 2016年12月09日 20:26
  • 1003

正则表达式入门经典(学习笔记八)——几个例子及解释汇总

1.不平衡的交替选择(a|ab)  假设正则表达式引擎在a之前的位置开始匹配,它首先尝试将第一个选项与该行中的第一个字符——也就是a进行匹配。匹配成功。这样正则表达式就不会再尝试匹配第二个选项了。于是...
  • cyhleo
  • cyhleo
  • 2011年07月29日 11:07
  • 3797

【前端学习笔记】Javascript中的正则表达式

复习字符串操作—————————————————————————–indexOf 查找字符 返回位置 charAt 查找位置 返回字符 substring 获取字符窜 split 分割字符串...
  • u014420383
  • u014420383
  • 2015年08月05日 23:45
  • 674

js正则表达式学习和总结

js正则表达式的相关学习和总结
  • liujie19901217
  • liujie19901217
  • 2016年04月22日 21:22
  • 5740

学习笔记_正则表达式

学习笔记_正则表达式学习日期:2016年10月2日 学习课程:正则表达式 - 廖雪峰的官方网站 正则表达式是一种用来匹配字符串的强有力的武器。它的设计思想是用一种描述性的语言来给字符串定义一个规则,...
  • weixin_35955795
  • weixin_35955795
  • 2016年10月08日 21:30
  • 194

正则表达式 学习笔记

匹配中文字符的正则表达式: [/u4e00-/u9fa5]限定符的概念: 非显式限定符(3 个):      *:出现0或多次      +:出现1或多次      ?:出现0或1次 显式限定符:  ...
  • ycs0501
  • ycs0501
  • 2008年03月13日 13:05
  • 334

正则表达式学习笔记!

/* 正则表达式. 是一种规则,是一种操作字符串的规则。 1,匹配。String  matches(regex) 2,获取匹配内容。 3,切割。 4,替换。 */ import jav...
  • ydcun
  • ydcun
  • 2012年08月08日 00:16
  • 517

学习笔记:正则表达式

Regex原博客放弃不再更新,原博客上部分学习笔记搬运到这个博客上来,这个文章是四月二十三号的学习笔记 正则表达式本质是一个字符串,是用来定义匹配规则,匹配一系列符合某个句法规则的字符串 在开发中,正...
  • qq_34061675
  • qq_34061675
  • 2017年05月01日 12:50
  • 4106

正则表达式..........学习笔记

本文目标如何使用本教程正则表达式到底是什么东西?入门测试正则表达式元字符字符转义重复字符类分枝条件反义分组后向引用零宽断言负向零宽断言注释贪婪与懒惰处理选项平衡组/递归匹配还有些什么东西没提到联系作者...
  • lai124793549
  • lai124793549
  • 2014年10月20日 01:36
  • 274
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:正则表达式学习笔记
举报原因:
原因补充:

(最多只允许输入30个字)