首頁 > web前端 > js教程 > 正規表示式之回溯引用backreference詳解_正規表示式

正規表示式之回溯引用backreference詳解_正規表示式

微波
發布: 2017-06-28 13:49:30
原創
1612 人瀏覽過

這篇文章主要介紹了正規表示式學習教程之回溯引用backreference,結合實例形式詳細分析了回溯引用的概念、功能及實現技巧,需要的朋友可以參考下

本文實例講述了正規表示式回溯引用backreference。分享給大家供大家參考,具體如下:

在所有例子中正則表達式匹配結果包含在源文本中的【和】之間,有的例子會使用Java來實現,如果是java本身正規表示式的用法,會在對應的地方說明。所有java例子都在JDK1.6.0_13下測試通過。

一、問題引入

一個在HTML頁面中符合標題標籤(H1—H6)的問題:

文字:

<body>
<h1>Welcome to my page</H1>
Content is pided into twosections:<br>
<h2>Introduction</h2>
Information about me.
<H2>Hobby</H2>
Information about my hobby.
<h2>This is invalid HTML</h3>
</body>
登入後複製
登入後複製

正規表示式:<[hH][1-6]>.*?

#結果:


Welcome to my page


Content is pided into twosections:

#Content is pided into twosections:
#Content is pided into twosections:

#Content is pided into twosections:
#Content is pided into twosections:

#Content is pided into twosections:
#Content 是
#【

Introduction


#Information about me.

Hobby

#Information about

」 my hobby.

This is invalid HTML

##

#分析:模式<[hH][1 -6]>符合任何一級標題的開始標籤,而且不區分大小寫,在這個例子中它匹配到了

匹配到了

、;這裡使用了懶惰型元字符

來匹配標籤中的文本,否則會匹配到從第一個開始標籤到最後一下結束標籤之間的內容。但從結果可以看出,有一個無效的標籤也匹配上了,即

,它們根本不能配對。要解決這個問題,就需要使用到回溯引用(backreference)。

二、回溯引用符合

回溯引用是指模式的後半部引用在前半部中定義的子表達式。 至於子表達式的使用、分割和引用,在前面已經介紹過了。現在來解決前面的範例:

文字:

<body>
<h1>Welcome to my page</H1>
Content is pided into twosections:<br>
<h2>Introduction</h2>
Information about me.
<H2>Hobby</H2>
Information about my hobby.
<h2>This is invalid HTML</h3>
</body>
登入後複製
登入後複製
正規表示式:

<[hH]([1-6])>.*?

結果:


Welcome to my page


Content is pided into twosections:

Introduction


#Information about me.

##【

Hobby

Information about my hobby.

This is invalid HTML

分析:首先匹配開始標題標籤的模式<[ hH]([1-6])>,使用括號把[1-6]做為子表達式,而匹配結束標題標籤模式為,其中\1表示引用第一個子表達式,即([1-6]),如果([1-6])匹配到的是1,那\1也匹配到1,如果匹配到2,那\1也匹配到2,所以最後一個無效的標題標籤就不會被配對到了。

PS:這裡再提供大家2款非常方便的正規表示式工具供大家參考使用:
JavaScript

正規表示式線上測試工具:

http://tools.jb51.net/regex/javascript
##正規則表達式線上產生工具:

######http://tools.jb51.net/regex/create_reg###

以上是正規表示式之回溯引用backreference詳解_正規表示式的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板