2023年政策修订增补工作正在进行中,欢迎参与!
  • Moegirl.ICU:萌娘百科流亡社群 581077156(QQ),欢迎对萌娘百科运营感到失望的编辑者加入
  • Moegirl.ICU:账号认领正在试运行,有意者请参照账号认领流程

模板:Regex/doc

萌娘百科,萬物皆可萌的百科全書!轉載請標註來源頁面的網頁連結,並聲明引自萌娘百科。內容不可商用。
跳至導覽 跳至搜尋

簡介

該模板為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}}