我正在尝试使用preg_match_all从网站上获取特定部分的出现,我之前已成功完成此操作,但现在的区别在于这些部分跨越换行符……我已经理解了,我应该可以用一些修饰符来做到这一点……
因此,相关网站上的部分结构如下:
<div id="LICRabatGuideAftale">
<something in between>
<div class="clear"></div>
</div>
<div id="LICRabatGuideAftale">
<something in between>
<div class="clear"></div>
</div>
<div id="LICRabatGuideAftale">
<something in between>
<div class="clear"></div>
</div>
所以我试图用LICRabatGuideAftale来清除所有事件……
我尝试过:
preg_match_all ("/LICRabatGuideAftale(.*)clear/s", $link_section, $link_array);
但它似乎没有将网站分成几个部分,但只是在数组中给了我一个条目…
解决方法:
使用 .*?代替 .*.的?使量词不情愿而不是贪婪,所以匹配将在第一个清除而不是最后一个清除.
在另一个答案中建议使用U修饰符也是可能的.这基本上颠倒了.*和.*的行为?分别使他们不情愿和贪婪.
标签:preg-match-all,php,regex 来源: https://codeday.me/bug/20190729/1568303.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。