2023年政策修订增补工作正在进行中,欢迎参与!
模板:Regex
跳至導覽
跳至搜尋
簡介
該模板為RegexParserFunctions模塊的封裝模板,使用基於PCRE庫的正則表達式對字符串的處理,包含下列功能:
- test:判斷字符串是否匹配正則
- match:返回與正則匹配的子串
- replace:根據正則替換字符串
若要將該模板置於其他字符串處理或邏輯判斷的模板中,建議先單獨拿出來測試,確保正則以及修飾符的正確。因為該模板已經屏蔽了原模塊拋出的系統級錯誤(系統級錯誤有可能導致在頁面後退時發生編輯丟失)。
用法與示例
關於修飾符的使用,請參考:PHP官方文檔:模式修飾符
該模板所有方法的ptn
參數均支持以<nowiki>
標籤包裹的格式傳入。
test
判斷字符串是否匹配正則,匹配則返回1,否則返回空。
{{regex|test|str=字符串 |ptn=正则 |mdf=修饰符 |then= 如果匹配则输出,默认为1 |else= 否则输出,默认为空}}
其中,str、ptn、then、else也分別對應匿名參數2、3、4、5。
- 示例:
{{regex|test|123,456|\d+,\d+|true|false}}
結果:true
match
返回與正則匹配的子串,若未匹配到,則返回空。
{{regex|match|str=字符串 |ptn=正则 |mdf=修饰符}}
其中,str和ptn也分別對應匿名參數2和3。
- 示例:
{{regex|match|123,456|,\d+}}
結果:{{#regex:123,456|/,\d+/}}
replace
根據正則替換字符串,若未匹配到,則原樣返回。
{{regex|replace|str=字符串 |ptn=正则 |mdf=修饰符 |rep=替换内容,默认为空字符串}}
其中,str、ptn、rep也分別對應匿名參數2、3、4。
- 示例1:
{{regex|replace|abc,dEf|mdf=i|,[a-z]+|000}} <!-- 使用修饰符“i”,设置大小写不敏感 -->
結果:{{#regex:abc,dEf|/,[a-z]+/i|000}}
- 示例2:
{{regex|replace|abc,def|(\w+),(\w+)|$1&$2}} <!-- 使用“$n”,引用捕获的子串 -->
結果:{{#regex:abc,def|/(\w+),(\w+)/|$1&$2}}
|