正值表示式匹配html標籤的屬性值
正規表示式是做文字解析工作必不可少的技能。如Web伺服器日誌分析,網頁前端開發等。很多高階文字編輯器都支援正規表示式的一個子集,熟練掌握正規表示式,經常能夠使你的一些工作事半功倍。例如統計程式碼行數,只需一個正則就搞定。巢狀Html標籤的匹配是正規表示式應用中一個比較難的話題,因為它涉及到的正則語法比較多,也比較難。因此也就更有研究的價值。
今天由於工作的需求,需要獲取html標籤的屬性值,立即想到了正規表示式,標籤如下:
<circle id="ap_test" cx="200" cy="2000" r="2" stroke="black" stroke-width="0" fill="red"/> <circle id="ap_test" cx="201" cy="2001" r="2" stroke="black" stroke-width="0" fill="red"/> <circle id="ap_test" cx="202" cy="2002" r="2" stroke="black" stroke-width="0" fill="red"/> <circle id="ap_test" cx="203" cy="2003" r="2" stroke="black" stroke-width="0" fill="red"/>
需要獲取<circle />標籤的cx、cy的屬性值,想了一會寫出了一個:
$circle是上面的circle標籤的內容
preg_match_all('/<\s*circle\s+[^>]*?cx\s*=\s*(\'|\")(.*?)\\1[^>]*?cy\s*=\s*(\'|\")(.*?)\\1[^>]*?\/?\s*>/i', $circle, $arr); var_dump($arr);
$arr[2]是cx的值 ,$arr[4]是cy的值.
下面給大家介紹下正則匹配閉合HTML標籤(支援巢狀)
任何複雜的正規表示式都是由簡單的子表示式組成的,要想寫出複雜的正則來,一方面需要有化繁為簡的功底,另外一方面,我們需要從正則引擎的角度去思考問題。關於正則引擎的原理,推薦《Mastering Regular Expression》中文名叫《精通正規表示式》。挺不錯的一本書。
OK,先確定我們要解決的問題——從一段Html文字中找出特定id的標籤的innerHTML。
這裡面最大的難點就是,Html標籤是支援巢狀的,怎麼能夠找到指定標籤相對應的閉合標籤呢?
我們可以這樣想,先匹配最前面的起始標籤,假設是div吧(<div),接著一旦遇到巢狀div,就“壓入堆疊”,後面如果遇到div閉合標籤了,就“彈出堆疊”。如果遇到閉合標籤的時候,堆疊裡面已經沒有東西了,那麼匹配結束,此結束標籤為正確的閉合標籤。
我之所以能夠這樣去思考,是因為我瞭解過正則的特性,我知道正則中的平衡組能夠實現我剛才說的“堆疊”操作。所以,如果我們要編寫複雜正規表示式,需要對正則的一些高階特性至少有所瞭解,這樣我們思考問題才有個方向。
================================
匹配任意閉合HTML標籤的正規表示式:
<(?<HtmlTag>[\w]+)[^>]*?>((?<Nested><\k<HtmlTag>[^>]*>)|</\k<HtmlTag>>(?<-Nested>)|.*?)*</\k<HtmlTag>>
如果只想匹配div標籤,可以使用下面的正規表示式:
<(?<HtmlTag>div)[^>]*?>((?<Nested><\k<HtmlTag>[^>]*>)|</\k<HtmlTag>>(?<-Nested>)|.*?)*</\k<HtmlTag>>
是的,你可以把div修改成任意你想要匹配的HTML標籤
如果想同時匹配多個HTML標籤,可以使用下面的正規表示式:
<(?<HtmlTag>(div|span|h1))[^>]*?>((?<Nested><\k<HtmlTag>[^>]*>)|</\k<HtmlTag>>(?<-Nested>)|.*?)*</\k<HtmlTag>>
你還可以繼續新增更多要匹配的標籤
如果想匹配包含ID的標籤,可以使用下面的正規表示式:
<(?<HtmlTag>[\w]+)[^>]*\s[iI][dD]=(?<Quote>["']?)footer(?(Quote)\k<Quote>)[^>]*?(/>|>((?<Nested><\k<HtmlTag>[^>]*>)|</\k<HtmlTag>>(?<-Nested>)|.*?)*</\k<HtmlTag>>)
這個正則匹配任意id為footer的HTML標籤
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/70015107/viewspace-2878900/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 正規表示式查詢具有指定屬性值的html標籤HTML
- 匹配HTML標籤的正規表示式HTML
- 匹配html標籤正規表示式HTML
- 匹配 HTML 標籤正規表示式HTML
- HTML標籤屬性HTML
- PHP正規表示式抓取某個標籤的特定屬性值的方法PHP
- HTML 常用的標籤和屬性HTML
- 常用的HTML標籤和屬性HTML
- HTML <a> 標籤的正規表示式HTML
- HTML 標籤與屬性大小寫HTML
- js給html標籤新增屬性JSHTML
- 正規表示式從<img>標籤中提取src屬性值圖片路徑
- HTML meta 標籤總結與屬性HTML
- HTML常用標籤或屬性全稱HTML
- 語義化你的HTML標籤和屬性HTML
- 自定義html標籤和表單屬性HTML
- 標籤的 src 屬性
- HTML5 <meta> 標籤屬性,所有meta用法HTML
- html的meta總結,html標籤中meta屬性使用介紹HTML
- HTML5 標籤、屬性及相容性速查表HTML
- DOM物件屬性(property)與HTML標籤特性(attribute)物件HTML
- 匹配HTML註釋的正規表示式HTML
- css匹配具有指定屬性值的元素CSS
- 獲取iframe標籤的src屬性值程式碼例項
- Maven屬性(properties)標籤的使用Maven
- script標籤的crossorigin屬性ROS
- 請教如何在標籤的dostart裡獲取當前頁面的URL地址以及父標籤的標籤型別和某個屬性的屬性值呢?型別
- HTML 布林屬性值HTML
- 利用正規表示式去除所有html標籤,只保留文字HTML
- HTML中你不得不知道的標籤及屬性HTML
- html5標籤的data-*屬性用法簡單介紹HTML
- 正規表示式匹配html中的圖片HTML
- input標籤autocomplete 屬性
- jquery對標籤屬性操作jQuery
- 使用 tpl 標籤和 for 讀取物件屬性值中的陣列物件陣列
- Struts標籤、ognl表示式、el表示式、jstl標籤庫這四者之間JS
- <checkBox>標籤的value屬性的作用
- 正則匹配閉合HTML標籤(支援巢狀)HTML巢狀