
高效抓取网页分页链接:解决QueryList选择器问题
本文介绍如何利用QueryList库从HTML代码中准确提取分页链接,特别是那些位于“共X页”提示后的链接。 问题在于原代码的选择器无法精准定位目标元素。
以下HTML片段展示了典型的分页导航区域,包含“共8页”提示和对应的页面链接: (此处应插入HTML片段,但因无法访问本地文件,故省略)
原代码使用range('.pagebox > a') 选择器,但.pagebox在实际HTML中并不存在,导致提取失败。
解决方案:直接使用更精准的CSS选择器div.page a,它能直接选中包含所有页码链接的标签。 无需使用range函数进行范围限定。
改进后的PHP代码如下:
['a', 'href']];$list = QueryList::get($url, null, [ 'headers' => [ 'User-Agent' => 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_3) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/80.0.3987.149 Safari/537.36', 'Accept-Encoding' => 'gzip, deflate, br', ]])->rules($rules)->find('div.page a') // 修改后的选择器->queryData();var_dump($list);?>
通过修改选择器,QueryList将直接提取div.page内所有标签的href属性值,从而获取所有页码链接。 此方法比使用range更简洁高效,并避免了选择器错误导致的匹配失败。 如果需要进一步筛选(例如只提取数字页码),可在queryData()之后进行数据处理。
以上就是网页数据提取:如何准确抓取“共X页”提示后的页面链接?的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1254195.html
微信扫一扫
支付宝扫一扫