
本文介绍在解析电商比价页面时,如何通过字符串预处理结合正则匹配,跳过顶部广告区块、准确提取所有真实销售店铺的 html 片段。核心思路是先定位广告区结束位置(如 `
在解析类似 ZAP.co.il 商品比价页 这类结构化但含干扰区块的 HTML 时,直接对全文使用 preg_match_all 匹配
✅ 推荐做法:分两步清洗,而非强行用正则识别“非广告”
-
定位并截断广告区:利用广告区与真实商品列表之间稳定的 DOM 分隔标识(如 、
המחירים
或 等),用 strstr() 提前剥离无关内容;- 在干净子串中精准匹配:对截取后的 HTML 片段执行结构化正则提取。
示例代码如下:
// 假设 $html 已通过 file_get_contents() 或 cURL 获取完整页面 $cleanHtml = strstr($html, '
'); // 从首个分隔符开始截取(含该标签) if ($cleanHtml === false) { // 兜底:若分隔符未找到,尝试备用标识(如 class="ResultsList") $cleanHtml = strstr($html, ''); } if ($cleanHtml) { // 在干净内容中匹配每个 StoreLine 区块(以 BuyButtons / SmartBuyButtons 结尾) $pattern = '/.*?<\/div\s*>\s*(?=)/isU'; preg_match_all($pattern, $cleanHtml, $matches); $storeBlocks = $matches[0]; // 每个元素即一个完整店铺区块(含起始和结束标签) } else { $storeBlocks = []; }⚠️ 注意事项:
立即学习“PHP免费学习笔记(深入)”;
- *避免 `.全局贪婪匹配**:务必使用.*?非贪婪模式 +/s(使.匹配换行)和/U`(PCRE_UNGREEDY)修饰符,防止跨区块误吞;
-
HTML 解析优先级建议:正则适用于简单、稳定结构;若页面结构多变或需深度遍历(如提取价格、店铺名、链接),强烈推荐改用 DOMDocument + XPath,例如:
$dom = new DOMDocument(); @$dom->loadHTML($cleanHtml, LIBXML_HTML_NOIMPLIED | LIBXML_HTML_NODEFDTD); $xpath = new DOMXPath($dom); $nodes = $xpath->query('//div[contains(@class,"StoreLine")]'); - 分隔符鲁棒性:生产环境应增加容错逻辑,例如用 stripos() 多关键词匹配(SortBy, ResultsList, ProductList),并设置最小截取长度阈值,防止误截空白内容。
总结:面对“跳过开头 N 个同类区块”的需求,正则不是万能解法;定位结构性锚点并预处理 HTML,才是稳定、可维护的工程实践。 将清洗逻辑前置,后续匹配自然简洁可靠。
相关文章
php获取本机ip与路由表有关吗_php查路由得ip法【技巧】
如何正确初始化依赖注入容器以避免属性为 null 的问题
php多维转一维跨编码兼容_php二维转一维编码统一处理【步骤】
php如何调用小程序云函数_php触发云函数执行方式【教程】
php判断多字节字符串长度_php多语言长度计算法【步骤】
本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
更多热门AI工具
相关专题
打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。
2914
2023.09.01
取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。
1737
2023.10.11
php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。
1568
2023.10.11
连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。
1120
2023.10.23
php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。
1566
2023.10.23
PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。
1669
2023.11.09
php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。
1310
2023.11.13
本专题系统讲解 Python 在自然语言处理(NLP)领域的基础方法与实战应用,涵盖文本预处理(分词、去停用词)、词性标注、命名实体识别、关键词提取、情感分析,以及常用 NLP 库(NLTK、spaCy)的核心用法。通过真实文本案例,帮助学习者掌握 使用 Python 进行文本分析与语言数据处理的完整流程,适用于内容分析、舆情监测与智能文本应用场景。
1
2026.01.27
热门下载
相关下载
精品课程
最新文章



