[英]How to properly escape a string for use in regular expression in PHP?
我试图逃避一个字符串,用于PHP中的正则表达式。 到目前为止我试过:
preg_quote(addslashes($string));
我认为我需要addslashes
才能正确解释字符串中的任何引号。 然后preg_quote
转义正则表达式字符。
但问题是引号是用反斜杠转义的,例如\\'
。 但是preg_quote
用另一个preg_quote
了反斜杠,例如\\\\'
。 所以这使得报价再次没有了。 切换这两个函数也不起作用,因为这会留下未转义的反斜杠,然后将其解释为特殊的正则表达式字符。
PHP中是否有一个函数来完成任务? 或者怎么做呢?
正确的方法是使用preg_quote并指定使用的模式分隔符 。
preg_quote()接受str并在每个字符前加一个反斜杠,这是正则表达式语法的一部分......字符是:
. \\ + * ? [ ^ ] $ ( ) { } = ! < > | : -
. \\ + * ? [ ^ ] $ ( ) { } = ! < > | : -
尝试使用反斜杠作为分隔符是一个坏主意。 通常你选择一个在模式中没有使用的角色。 常用的是斜线 /pattern/
, 波浪线 ~pattern~
, 数字符号 #pattern#
或百分号 %pattern%
。 也可以使用括号样式分隔符:( (pattern)
您在@CasimiretHippolyte和@anubhava的评论中提到的正则修改。
$pattern = '/(?<![a-z])' . preg_quote($string, "/") . '/i';
也许想用\\b
字边界 。 无需任何额外的逃避。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.