如何解决使用克拉^时,preg_match_all不匹配
| 我正在使用“ 0”在HTML文件中查找URL。 URL始终显示在行的开头,没有前导空格,如下所示:<A HREF=\"/link/to/here\"><strong>Next</strong></A>
我用它来匹配它:
preg_match_all(\'|^<A HREF=\"(?<url>.*?)\"><strong>Next</strong>|\',$html,$url_matches);
直到我删除了克拉(^)字符,它才起作用。我以为克拉与生产线的起点匹配。为什么会导致我的比赛失败?
解决方法
您必须添加
m
修饰符:
preg_match_all(\'|^<A HREF=\"(?<url>.*?)\"><strong>Next</strong>|m\',$html,$url_matches);
那么^
在行的开头匹配,否则它将仅在整个字符串的开头匹配。
更多信息:http://php.net/manual/zh/reference.pcre.pattern.modifiers.php
, ^
匹配字符串开头而不是行首。使用m
(\“多行\”)修饰符://m
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。