模板:Regex
1.38>牛腩面2022年7月2日 (六) 19:00的版本 (导入1个版本)
本页面之全部或部分原来自萌娘百科的模板:Regex,依 CC BY-NC-SA 3.0 CN 授权引入;原贡献者可以在这里看到。 |
简介
该模板为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+}}
结果:,456
replace
根据正则替换字符串,若未匹配到,则原样返回。
{{regex|replace|str=字符串 |ptn=正则 |mdf=修饰符 |rep=替换内容,默认为空字符串 |lim= 次数限制,默认为无限制}}
其中,str、ptn、rep、lim也分别对应匿名参数2、3、4、5。
- 示例1:
{{regex|replace|abc,dEf|mdf=i|,[a-z]+|000}} <!-- 使用修饰符“i”,设置大小写不敏感 -->
结果:abc000
- 示例2:
{{regex|replace|abc,def|(\w+),(\w+)|$1&$2}} <!-- 使用“$n”,引用捕获的子串 -->
结果:abc&def