欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

phpQuery采集网页实现代码实例

程序员文章站 2022-10-11 21:56:50
前言  平时开发中可能遇到一个问题。采集网页,小偷程序等等。各种花式秀正则的话,虽然能体现出geek,但是我觉得做事却不够优雅。采集到的网页说白了也是dom,jquery各种优...

前言

  平时开发中可能遇到一个问题。采集网页,小偷程序等等。各种花式秀正则的话,虽然能体现出geek,但是我觉得做事却不够优雅。采集到的网页说白了也是dom,jquery各种优雅地获取节点。幸好,有这个类库,帮我们解决了这个,那就是phpquery.

为什么使用phpquery

phpquery是基于php5新添加的domdocument。而domdocument则是专门用来处理html/xml。它提供了强大的xpath选择器及其他很多html/xml操作函数,使得处理html/xml起来非常方便。

尤其对于新手,看到一堆”不知所云”的字符评凑在一起,有种脑袋都要炸了的感觉。如果要分离的对象没有太明显的特征,正则写起来更是麻烦。

学习成本低,jquery是php程序员的标配,那么懂jquery的话,是可以无缝衔接的,学习成本几乎为0。选择器,节点,节点信息,over

下载地址

(需要*,或者自行百度phpquery)

实验

  既然开始了,那么就做个实验,比如我们要获取sf的所有标签名称https://segmentfault.com/tags,审查元素,得到部分标签属性。<a class="tag" data-original-title="负载均衡">负载均衡</a>

demo

<?php
  
  require("phpquery.php");//导入phpquery库
  $html   = phpquery::newdocumentfile("https://segmentfault.com/tags");
  $hreflist = pq(".tag"); //获取标签为a的所有对象$(".tag")

  foreach ($hreflist as $href) {
    echo $href->getattribute("data-original-title"),"<br>";
  }

结果

phpQuery采集网页实现代码实例

总结

0.网页采集真特么无脑暴力,成功绕过恶心的正则

1.写法参照jquery

2.体会dom的思想

3.此类库并非万金油,更适合网页采集

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。