本站资源收集于互联网,不提供软件存储服务,每天免费更新优质的软件以及学习资源!

PHP正则表达式:如何匹配两个标签之间的内容且排除包含中文冒号的字符串?

网络教程 app 1℃

PHP正则表达式如何匹配两个标签之间的内容且排除包含中文冒号的字符串

php正则如何匹配除中文加冒号外的字符串?

在php中,如何使用正则表达式匹配两个

标签之间的内容,但排除包含中文加冒号(:)格式的字符串呢?

示例:

要匹配的字符串:

<td>我是张三分</td><td>张无忌: 你真的是张三分?</td>

问题:

使用正则表达式/

. ?匹配会匹配到中文加冒号,而 /[^(x{4e00}-x{9fa5}[::])] }无法正常匹配。

解决方案:

使用preg_match_all函数和否定前瞻断言:

preg_match_all(‘/<td>(?!.*[x{4e00}-x{9fa5}:]).*&</td>/u’, $input, $matches);

其中:

/u修饰符启用unicode编码。(?!.*[x{4e00}-x{9fa5}:])否定前瞻断言意味着该模式仅匹配后面没有中文加冒号的字符串。

以上就是PHP正则表达式:如何匹配两个标签之间的内容且排除包含中文冒号的字符串?的详细内容,更多请关注范的资源库其它相关文章!

转载请注明:范的资源库 » PHP正则表达式:如何匹配两个标签之间的内容且排除包含中文冒号的字符串?

喜欢 (0)