JavaScript中的正则表达式解析Word下载.docx
- 文档编号:17882995
- 上传时间:2022-12-11
- 格式:DOCX
- 页数:11
- 大小:23.10KB
JavaScript中的正则表达式解析Word下载.docx
《JavaScript中的正则表达式解析Word下载.docx》由会员分享,可在线阅读,更多相关《JavaScript中的正则表达式解析Word下载.docx(11页珍藏版)》请在冰豆网上搜索。
\.一个.直接量
\*一个*直接量
\+一个+直接量
\?
一个?
直接量
\|一个|直接量
\(一个(直接量
\)一个)直接量
\[一个[直接量
\]一个]直接量
\{一个{直接量
\}一个}直接量
\XXX由十进制数XXX指定的ASCII码字符
\Xnn由十六进制数nn指定的ASCII码字符
\cX控制字符^X.例如,\cI等价于\t,\cJ等价于\n
___________________________________________________
如果想在正则表达式中使用特别的标点符号,必须在他们之前加上一个"
\"
.
2.字符类
将独立的直接符放进中括号内就能组合成字符类.一个字符类和他所包含的所有一个字符都匹配,所以正则表达式/[abc]/和字母"
a"
"
b"
c"
中的所有一个都匹配.另外还能定义否定字符类,这些类匹配的是除那些包含在中括号之内的字符外的所有字符.定义否定字符尖时,要将一个^符号作为从左中括号算起的第一个字符.正则表达式的集合是/[a-zA-z0-9]/.
由于某些字符类非常常用,所以JavaScript的正则表达式语法包含一些特别字符和转义序列来表示这些常用的类.例如,\s匹配的是空格符,制表符和其他空白符,\s匹配的则是空白符之外的所有字符.
正则表灰式的字符类
____________________________________________________
[...]位于括号之内的任意字符
[^...]不在括号之中的任意字符
.除了换行符之外的任意字符,等价于[^\n]
\w所有单字字符,等价于[a-zA-Z0-9]
\W所有非单字字符,等价于[^a-zA-Z0-9]
\s所有空白符,等价于[\t\n\r\f\v]
\S所有非空白符,等价于[^\t\n\r\f\v]
\d所有数字,等价于[0-9]
\D除了数字之外的所有字符,等价于[^0-9]
[\b]一个退格直接量(特例)
________________________________________________________________
3.复制
用以上的正则表式的语法,能把两位数描述成/\d\d/,把四位数描述成/\d\d\d\d/.但我们还没有一种方法能用来描述具有任意多数位的数字或是个
字符串.这个串由三个字符及跟随在字母之后的一位数字构成.这些复杂的模式使用的正则表达式语法指定了该表达式中每个元素要重复出现的次数.
指定复制的字符总是出目前他们所作用的模式后面.由于某种复制类型相当常用.所以有一些特别的字符专门用于表示他们.例如:
+号匹配的就是复制前一模式一次或多次的模式.下面的表列出了复制语法.先看一个例子:
/\d{2,4}///匹配2到4间的数字.
/\w{3}\d?
///匹配三个单字字符和一个任意的数字.
/\s+java\s+///匹配字符串"
并且该串前后能有一个或多个空格.
/[^"
]*///匹配零个或多个非引号字符.
正则表达式的复制字符
字符含义
__________________________________________________________________
{n,m}匹配前一项至少n次,不过不能超过m次
{n,}匹配前一项n次,或多次
{n}匹配前一项恰好n次
?
匹配前一项0次或1次,也就是说前一项是可选的.等价于{0,1}
+匹配前一项1次或多次,等价于{1,}
*匹配前一项0次或多次.等价于{0,}
___________________________________________________________________
4.选择,分组和引用
正则表达式的语法还包括指定选择项,对子表达式分组和引用前一子表达式的特别字符.字符|用于分隔供选择的字符.例如:
/ab|cd|ef/匹配的是字符串"
ab"
或是字符串"
cd"
又或"
ef"
./\d{3}|[a-z]{4}/匹配的是要么是个三位数,要么是四个小写字母.在正则表达式中括号具有几种作用.他的主要作用是把独立的项目分组成子表达式,以便能像处理一个独立的单元那种用*、+或?
来处理那些项目.例如:
/java(script)?
/匹配的是字符串"
其后既能有"
script"
也能没有./(ab|cd)+|ef)/匹配的既能是字符串"
也能是字符串"
或"
的一次或多次重复.
在正则表达式中,括号的第二个用途是在完整的模式中定义子模式。
当一个正则表达式成功地和目标字符串相匹配时,能从目标串中抽出和括号中的子模式相匹配的部分.例如,假定我们正在检索的模式是个或多个字母后面跟随一位或多位数字,那么我们能使用模式/[a-z]+\d+/.不过由于假定我们真正关心的是每个匹配尾部的数字,那么如果我们将模式的数字部分放在括号中(/[a-z]+(\d+)/),我们就能从所检索到的所有匹配中抽取数字了,之后我们会对此进行解析的.
代括号的子表达式的另一个用途是,允许我们在同一正则表达式的后面引用前面的子表达式.这是通过在字符串\后加一位或多位数字来实现的.数字指的是代括号的子表达式在正则表达式中的位置.例如:
\1引用的是第一个代括号的子表达式.\3引用的是第三个代括号的子表达式.注意,由于子表达式能嵌套在其他子表达式中,所以他的位置是被计数的左括号的位置.
例如:
在下面的正则表达式被指定为\2:
/([Jj]ava([Ss]cript))\sis\s(fun\w*)/
对正则表达式中前一子表达式的引用所指定的并不是那个子表达式的模式,而是和那个模式相匹配的文本.这样,引用就不只是帮助你输入正则表达式的重复部分的快捷方式了,他还实施了一条规约,那就是个字符串各个分离的部分包含的是完全相同的字符.例如:
下面的正则表达式匹配的就是位于单引号或双引号之内的所有字符.不过,他需求开始和结束的引号匹配(例如两个都是双引号或都是单引号):
/[’"
][^’"
]*[’"
]/
如果需求开始和结束的引号匹配,我们能使用如下的引用:
/([’"
])[^’"
]*\1/
\1匹配的是第一个代括号的子表达式所匹配的模式.在这个例子中,他实施了一种规约,那就是开始的引号必须和结束的引号相匹配.注意,如果反斜杠后跟随的数字比代括号的子表达式数多,那么他就会被解析为一个十进制的转义序列,而不是个引用.你能坚持使用完整的三个字符来表示转义序列,这们就能避免混淆了.例如,使用\044,而不是\44.下面是正则表达式的选择、分组和引用字符:
______________________________________
|选择.匹配的要么是该符号左边的子表达式,要么他右边的子表达式
(...)分组.将几个项目分为一个单元.这个单元可由*、+、?
和|等符号使用,而且还能记住和这个组匹配的字符以供此后引用使用
\n和第n个分组所匹配的字符相匹配.分组是括号中的子表达式(可能是嵌套的).分组号是从左到右计数的左括号数
5.指定匹配的位置
我们已看到了,一个正则表达式中的许多元素才能够匹配字符串的一个字符.例如:
\s匹配的只是个空白符.更有一些正则表达式的元素匹配的是字符之间宽度为0的空间,而不是实际的字符例如:
\b匹配的是个词语的边界,也就是处于一个/w字字符和一个\w非字字符之间的边界.像\b这样的字符并不指定所有一个匹配了的字符串中的字符,他们指定的是匹配所发生的合法位置.有时我们称这些元素为正则表达式的锚.因为他们将模式定位在检索字符串中的一个特定位置.最常用的锚元素是^,他使模式依赖于字符串的开头,而锚元素$则使模式定位在字符串的末尾.
要匹配词"
javascript"
我们能使用正则表达式/^javascript$/.如果我们想检索"
这个词自身(不像在"
中那样作为前缀),那么我们能使用模式/\sjava\s/,他需求在词语java之前和之后都有空格.不过这样作有两个问题.第一:
如果"
出目前一个字符的开头或是结尾.该模式就不会和之匹配,除非在开头和结尾处有一个空格.第二:
当这个模式找到一个和之匹配的字符时,他返回的匹配的字符串前端和后端都有空格,这并不是我们想要的.因此,我们使用词语的边界\b来代替真正的空格符\s进行匹配.结果表达式是/\bjava\b/.
下面是正则表达式的锚字符:
____________________________________________________________________
^匹配的是字符的开头,在多行检索中,匹配的是一行的开头
$匹配的是字符的结尾,在多行检索中,匹配的是一行的结尾
\b匹配的是个词语的边界.简而言之就是位于字符\w和\w之间的位置(注意:
[\b]匹配的是退格符)
\B匹配的是非词语的边界的字符
_____________________________________________________________________
6.属性
有关正则表达式的语法更有最后一个元素,那就是正则表达式的属性,他说明的是高级模式匹配的规则.和其他正则表达式语法不同,属性是在/符号之外说明的.即他们不出目前两个斜杠之间,而是位于第二个斜杠之后.javascript1.2支持两个属性.属性i说明模式匹配应该是大小写不敏感的.属性g说明模式匹配应该是全局的.也就是说,应该找出被检索的字符串中所有的匹配.这两种属性联合起来就能执行一个全局的,大小写不敏感的匹配.
要执行一个大小不敏感的检索以找到词语"
(或是"
、"
JAVA"
等)的第一个具体值,我们能使用大小不敏感的正则表达式/\bjava\b/i.如果要在一个字符串中找到"
所有的具体值,我们还能添加属性g,即/\bjava\b/gi.
以下是正则表达式的属性:
_________________________________________
i执行大小写不敏感的匹配
g执行一个全局的匹配,简而言之,就是找到所有的匹配,而不是在找到第一个之后就停止了
除属性g和i之外,正则表达式就没有其他像属性相同的特性了.如果将构造函数RegExp的静态属性multiline设置为true,那么模式匹配将以多行的模式进行.在这种模式下,锚字符^和$匹配的不只是检索字符串的开头和结尾,还匹配检索字符串内部的一行的开头和结尾.例如:
模式/Java$/匹配的是"
Java"
不过并不匹配"
Java\nisfun"
.如果我们设置了multiline属性,那么后者也将被匹配:
RegExp.multiline=true;
正则表达式(regularexpression)对象包含一个正则表达式模式(pattern)。
他具有用正则表达式模式去匹配或代替一个串(string)中特定字符(或字符集合)的属性(properties)和方法(methods)。
要为一个独立的正则表达式添加属性,能使用正则表达式构造函数(constructorfunction),无论何时被调用的预设置的正则表达式拥有静态的属性(thepredefinedRegExpobjecthasstaticpropertiesthataresetwheneveranyregularexpressionisused,我不知道我翻得对不对,将原文列出,请自行翻译)。
∙创建:
一个文本格式或正则表达式构造函数
文本格式:
/pattern/flags
正则表达式构造函数:
newRegExp("
pattern"
[,"
flags"
]);
∙参数说明:
pattern--一个正则表达式文本
flags--如果存在,将是以下值:
g:
全局匹配
i:
忽略大小写
gi:
以上组合
[注意]文本格式的参数不用引号,而在用构造函数时的参数需要引号。
如:
/ab+c/inewRegExp("
ab+c"
"
i"
)是实现相同的功能。
在构造函数中,一些特别字符需要进行转意(在特别字符前加"
)。
re=newRegExp("
\\w+"
)
正则表达式中的特别字符
字符
含意
\
做为转意,即通常在"
后面的字符不按原来意义解释,如/b/匹配字符"
,当b前面加了反斜杆后/\b/,转意为匹配一个单词的边界。
-或-
对正则表达式功能字符的还原,如"
*"
匹配他前面元字符0次或多次,/a*/将匹配a,aa,aaa,加了"
后,/a\*/将只匹配"
a*"
。
^
匹配一个输入或一行的开头,/^a/匹配"
anA"
,而不匹配"
Ana"
$
匹配一个输入或一行的结尾,/a$/匹配"
*
匹配前面元字符0次或多次,/ba*/将匹配b,ba,baa,baaa
+
匹配前面元字符1次或多次,/ba*/将匹配ba,baa,baaa
匹配前面元字符0次或1次,/ba*/将匹配b,ba
(x)
匹配x保存x在名为$1...$9的变量中
x|y
匹配x或y
{n}
精确匹配n次
{n,}
匹配n次以上
{n,m}
匹配n-m次
[xyz]
字符集(characterset),匹配这个集合中的任一一个字符(或元字符)
[^xyz]
不匹配这个集合中的所有一个字符
[\b]
匹配一个退格符
\b
匹配一个单词的边界
\B
匹配一个单词的非边界
\cX
这儿,X是个控制符,/\cM/匹配Ctrl-M
\d
匹配一个字数字符,/\d/=/[0-9]/
\D
匹配一个非字数字符,/\D/=/[^0-9]/
\n
匹配一个换行符
\r
匹配一个回车符
\s
匹配一个空白字符,包括\n,\r,\f,\t,\v等
\S
匹配一个非空白字符,等于/[^\n\f\r\t\v]/
\t
匹配一个制表符
\v
匹配一个重直制表符
\w
匹配一个能组成单词的字符(alphanumeric,这是我的意译,含数字),包括下划线,如[\w]匹配"
$5.98"
中的5,等于[a-zA-Z0-9]
\W
匹配一个不能组成单词的字符,如[\W]匹配"
中的$,等于[^a-zA-Z0-9]。
说了这么多了,我们来看一些正则表达式的实际应用的例子:
E-mail地址验证:
functiontest_email(strEmail){
varmyReg=/^[_a-z0-9]+@([_a-z0-9]+\.)+[a-z0-9]{2,3}$/;
if(myReg.test(strEmail))returntrue;
returnfalse;
}
HTML代码的屏蔽
functionmask_HTMLCode(strInput){
varmyReg=/<
(\w+)>
/;
returnstrInput.replace(myReg,"
&
lt;
$1&
gt;
"
正则表达式对象的属性及方法
预定义的正则表达式拥有有以下静态属性:
input,multiline,lastMatch,lastParen,leftContext,rightContext和$1到$9。
其中input和multiline能预设置。
其他属性的值在执行过exec或test方法后被根据不同条件赋以不同的值。
许多属性同时拥有长和短(perl风格)的两个名字,并且,这两个名字指向同一个值。
(JavaScript模拟perl的正则表达式)
正则表达式对象的属性
属性
含义
$1...$9
如果他(们)存在,是匹配到的子串
$_
参见input
$*
参见multiline
$&
参见lastMatch
$+
参见lastParen
$`
参见leftContext
$’
参见rightContext
constructor
创建一个对象的一个特别的函数原型
global
是否在整个串中匹配(bool型)
ignoreCase
匹配时是否忽略大小写(bool型)
input
被匹配的串
lastIndex
最后一次匹配的索引
lastParen
最后一个括号括起来的子串
leftContext
最近一次匹配以左的子串
multiline
是否进行多行匹配(bool型)
prototype
允许附加属性给对象
rightContext
最近一次匹配以右的子串
source
正则表达式模式
正则表达式对象的方法
方法
compile
正则表达式比较
exec
执行查找
test
进行匹配
toSource
返回特定对象的定义(literalrepresenting),其值可用来创建一个新的对象。
重载Object.toSource方法得到的。
toString
返回特定对象的串。
重载Object.toString方法得到的。
valueOf
返回特定对象的原始值。
重载Object.valueOf方法得到
例子
<
scriptlanguage="
JavaScript"
>
varmyReg=/(\w+)\s(\w+)/;
varstr="
JohnSmith"
;
varnewstr=str.replace(myReg,"
$2,$1"
document.write(newstr);
/script>
将输出"
Smith,John"
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- JavaScript 中的 正则 表达式 解析
![提示](https://static.bdocx.com/images/bang_tan.gif)