phpQuery—基于jQuery的PHP实现
先来看看官方简介:
phpQuery is a server-side, chainable, CSS3 selector driven Document Object Model (DOM) API based on jQuery JavaScript Library.
Library is written in PHP5 and provides additional Command Line Interface (CLI).
存在的意义
我们有时需要抓取一个网页的内容,但只需要特定部分的信息,通常会用正则来解决,这当然没有问题。正则是一个通用解决方案,但特定情况下,往往有更简单快 捷的方法。比如你想查询一个编程方面的问题,当然可以使用Google,但* 作为一个专业的编程问答社区,会提供给你更多,更靠谱的答案。
对于html页面,不应该使用正则的原因主要有3个
1、编写条件表达式比较麻烦
尤其对于新手,看到一堆”不知所云”的字符评凑在一起,有种脑袋都要炸了的感觉。如果要分离的对象没有太明显的特征,正则写起来更是麻烦。
2、效率不高
对于php来说,正则应该是没有办法的办法,能通过字符串函数解决的,就不要劳烦正则了。用正则去处理一个30多k的文件,效率不敢保证。
3、有phpQuery
如果你使用过jQuery,想获取某个特定元素应该是轻而易举的事情,phpQuery让这成为了可能。
浅析phpQuery
phpQuery是基于php5新添加的DOMDocument。而DOMDocument则是专门用来处理html/xml。它提供了强大xpath选 择器及其他很多html/xml操作函数,使得处理html/xml起来非常方便。那为什么不直接使用呢?这个,去看一下官网的函数列表 就知道了,如果对自己的记忆力很有信心, 不妨一试。
几个简单的例子
获取蓝色理想最热的招聘职位
- include 'phpQuery.php';
- phpQuery::newDocumentFile('http://job.blueidea.com');
- $companies = pq('#hotcoms .coms')->find('div');
- foreach($companies as $company)
- {
- echo pq($company)->find('h3 a')->text()."
"; - }
小结
- pq()就像jQuery里的$()
- 基本上jQuery的选择器都可以用在phpQuery上,只要把’.'变成’->’
- phpQuery提供了好几种载入文件的方法,有的使用字符串,有的使用文件(包括url),选 择的时候要注意
- 基本上这一页 就很能说明问题了
其他解析器
simplehtmldom 也是个不错的html解析器,使用起来也挺方便,是基 于正则的,所以没有phpQuery那么强大,如果没有太高的要求,也基本够用了。
yql 是yahoo出的一款使用类似SQL的语言,来获取相应的数据,也很强大,无须任何类 库,可以直接调用,支持xpath,如果对SQL语句比较熟悉的话,可以考虑yql。
>>QueryPath, php上的jQuery
-----------------------------------------------------
在网页采集的时候,通常都会用到正则表达式。但是有时候对于正则不太好的同学,比如我,那就杯具了。。如今google的项目里有个phpQuery , 顾名思义query,完全类似于jquery的语法,但这是服务器端的,总体来说就是可以用php来直接采集对应的网页内容了,真的是太方便了, 它让一切变得可能......
phpQuery is a server-side, chainable, CSS3 selector driven Document Object Model (DOM) API based on jQuery JavaScript Library.
Library is written in PHP5 and provides additional Command Line Interface (CLI).
项目下载地址:http://code.google.com/p/phpquery/
如果你使用过jQuery,你会发现这一切是如此的相象。
如何快速方便的获取到网页的 title?
上一篇: 同一个编辑器EclipsePHP Studio v1.2.2编纂的两个页面,print_r输出为何字体大小格式不一致? 用ajax.php正常,用osg_aja
下一篇: 如何在三到六个月,成为一名全栈工程师
推荐阅读
-
实现Nginx中使用PHP-FPM时记录PHP错误日志的配置方法
-
jQuery插件HighCharts实现的2D面积图效果示例【附demo源码下载】
-
jQuery animate()实现背景色渐变效果的处理方法【使用jQuery.color.js插件】
-
jQuery插件HighCharts实现的2D条状图效果示例【附demo源码下载】
-
使用jQuery实现一个类似GridView的编辑,更新,取消和删除的功能
-
基于Docker的PHP调用基于Docker的Mysql数据库
-
PHP中设置时区,记录日志文件的实现代码
-
PHP查询数据库中满足条件的记录条数(两种实现方法)
-
jQuery序列化form表单数据为JSON对象的实现方法
-
PHP获取http请求的头信息实现步骤