phpQuery采集网页实现代码实例


Posted in PHP onApril 02, 2020

前言

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

为什么使用phpQuery

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

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

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

下载地址

https://code.google.com/archive/p/phpquery/downloads(需要翻墙,或者自行百度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.此类库并非万金油,更适合网页采集

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

PHP 相关文章推荐
发布一个用PHP fsockopen写的HTTP下载的类
Feb 22 PHP
php设计模式之观察者模式的应用详解
May 21 PHP
解析htaccess伪静态的规则
Jun 18 PHP
json的键名为数字时的调用方式(示例代码)
Nov 15 PHP
PHP json_decode函数详细解析
Feb 17 PHP
PHP程序员基本要求和必备技能
May 09 PHP
PHP动态页生成静态页的3种常用方法
Nov 13 PHP
Mac系统下使用brew搭建PHP(LNMP/LAMP)开发环境
Mar 03 PHP
浅谈Laravel队列实现原理解决问题记录
Aug 19 PHP
php实现的生成迷宫与迷宫寻址算法完整实例
Nov 06 PHP
PHP实现普通hash分布式算法简单示例
Aug 06 PHP
php中isset与empty函数的困惑与用法分析
Jul 05 PHP
通过PHP的Wrapper无缝迁移原有项目到新服务的实现方法
Apr 02 #PHP
php计数排序算法的实现代码(附四个实例代码)
Mar 31 #PHP
php设计模式之观察者模式实例详解【星际争霸游戏案例】
Mar 30 #PHP
TP5框架实现上传多张图片的方法分析
Mar 29 #PHP
thinkphp框架无限级栏目的排序功能实现方法示例
Mar 29 #PHP
php查看一个变量的占用内存的实例代码
Mar 29 #PHP
tp5框架前台无限极导航菜单类实现方法分析
Mar 29 #PHP
You might like
PHP GD 图像处理组件的常用函数总结
2010/04/28 PHP
php图像处理函数大全(推荐收藏)
2013/07/11 PHP
PHP身份证校验码计算方法
2016/08/10 PHP
PHP控制反转(IOC)和依赖注入(DI)
2017/03/13 PHP
php双层循环(九九乘法表)
2017/10/23 PHP
PHP基于DateTime类解决Unix时间戳与日期互转问题【针对1970年前及2038年后时间戳】
2018/06/13 PHP
PHP实现PDO操作mysql存储过程示例
2019/02/13 PHP
phpstudy后门rce批量利用脚本的实现
2019/12/12 PHP
javascript中运用闭包和自执行函数解决大量的全局变量问题
2010/12/30 Javascript
jQuery实现异步获取json数据的2种方式
2014/08/29 Javascript
基于javascript实现浏览器滚动条快到底部时自动加载数据
2015/11/30 Javascript
js实现C#的StringBuilder效果完整实例
2015/12/22 Javascript
浅谈Vuex的状态管理(全家桶)
2017/11/04 Javascript
NodeJS实现一个聊天室功能
2019/11/25 NodeJs
React组件设计模式之组合组件应用实例分析
2020/04/29 Javascript
vue tab切换,解决echartst图表宽度只有100px的问题
2020/07/19 Javascript
python抓取某汽车网数据解析html存入excel示例
2013/12/04 Python
python调用机器喇叭发出蜂鸣声(Beep)的方法
2015/03/23 Python
Python使用pyodbc访问数据库操作方法详解
2018/07/05 Python
python 用下标截取字符串的实例
2018/12/25 Python
Django实现文件上传下载功能
2019/10/06 Python
Python安装whl文件过程图解
2020/02/18 Python
多视角3D可旋转的HTML5 Logo动画
2016/03/02 HTML / CSS
瑞典首都斯德哥尔摩的多元奢侈时尚品牌:Acne Studios
2017/07/09 全球购物
意大利在线大学图书馆:Libreria universitaria
2019/07/16 全球购物
《吃水不忘挖井人》教学反思
2014/04/15 职场文书
优秀党支部书记事迹材料
2014/05/29 职场文书
2015年师德师风承诺书
2015/01/22 职场文书
大学生自荐信怎么写
2015/03/26 职场文书
慈善献爱心倡议书
2015/04/27 职场文书
爱国电影观后感
2015/06/19 职场文书
教师节作文之小学四年级
2019/09/03 职场文书
手把手教你从零开始react+antd搭建项目
2021/06/03 Javascript
如何使用 resize 实现图片切换预览功能
2021/08/23 HTML / CSS
tomcat下部署jenkins的方法
2022/05/06 Servers
nginx 添加http_stub_status_module模块
2022/05/25 Servers