欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

如何使用正則匹配最后一個字符串詳解

 更新時間:2021年04月13日 11:35:16   作者:putline  
這篇文章主要給大家介紹了關(guān)于如何使用正則匹配最后一個字符串的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

前幾天遇到一個需求,輸入的是

<user>
    <user>
        <name>a</name>
    </user>
    <user>
        <name>a</name>
    </user>
</user>
<password>123</password>

要求拿到

<user>
    <user>
        <name>a</name>
    </user>
    <user>
        <name>a</name>
    </user>
</user>

也就是去掉最后一個</user>后面的字符串。

方法有很多,我首先想到的是用正則匹配去掉</user>后面的字符串。

最后寫出來的表達式是(?<=</user>)(?![\w\W]*</user>)[\w\W]+。

首先用(?<=</user>)匹配所有前面是</user>的位置,如圖,總共有三個位置。

這里寫圖片描述

這里我們正則表達式(?<=</user>)的意思就是匹配的位置之前的字符串是</user>,也就是我們匹配到的位置在</user>之后。

這里用到了正則表達式語法中的斷言,有的書上也稱該語法為預查或者環(huán)視,都是一樣的用法。有如下語法:
(?=pattern) 零寬正向先行斷言 (?!pattern) 零寬負向先行斷言 (?<=pattern) 零寬正向后行斷言 (?<!pattern) 零寬負向后行斷言

這里用到的是(?<=pattern),零寬表示它匹配的是在字符串中的位置,如同^匹配字符串串首,$匹配字符串串尾。正向代表它必須滿足pattern。后行代表它匹配的位置在pattern之后。

^匹配字符串串首

其次,再這三個位置上進行篩選,能夠看出這三個位置的區(qū)別是后面是否有</user>,如果沒有的話那么它就是最后一個</user>后面的位置。在之前的表達式后面添上(?![\w\W]*?</user>)此時表達式變?yōu)?code>(?<=</user>)(?![\w\W]*?</user>)。

這里寫圖片描述

能夠看到得到了最后一個匹配結(jié)果。

這里的正則表達式(?!pattern) 是零寬負向先行斷言,也就是它會往后匹配pattern,匹配到的位置在pattern之前,并且匹配到的字符串必須不滿足pattern。

(?![\w\W]*?</user>)的意思是在匹配到的位置后面必須不是[\w\W]*?</user>,\w匹配的是[a-zA-Z0-9_]即匹配字母數(shù)字和下劃線,而\W匹配的是[^a-zA-Z0-9_]即不是字母數(shù)字也不是下劃線的字符,同時匹配這兩個就相當于匹配任意字符。[\w\W]后面的*代表匹配0-任意多次,后面的?代表懶惰模式,即只要滿足條件就立即返回。

最后,在之前的正則表達式后面加上[\w\W]+貪婪匹配即盡可能多的匹配該位置后面的字符串。最終的正則表達式是(?<=</user>)(?![\w\W]*?</user>)[\w\W]*

這里寫圖片描述

最后的最后用四張圖簡單地描述四種斷言的不同之處。

這里輸入的字符串都是123456。

(?=3),它匹配的位置是后面的字符為3的位置。

這里寫圖片描述 

(?<=3),它匹配的位置是前面的字符為3的位置。

這里寫圖片描述 

(?!3)匹配的位置是后面的字符不為3的位置,可以看到箭頭所指的地方?jīng)]有被匹配到,其他位置都被匹配到了。

這里寫圖片描述

(?<!3)匹配的位置是前面的字符不為3的位置,可以看到箭頭所指的地方?jīng)]有被匹配到,其他位置都被匹配到了。

這里寫圖片描述

總結(jié)

到此這篇關(guān)于如何使用正則匹配最后一個字符串詳解的文章就介紹到這了,更多相關(guān)正則匹配最后一個字符串內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評論