phpQuery,如jQuery一样轻松处理轻松处理DOM文档内容

回复 星标
更多
«
phpQuery,如jQuery一样轻松处理轻松处理DOM文档内容
»
-
-

phpQuery是一个基于PHP的服务端开源项目,它可以让PHP开发人员轻松处理DOM文档内容,比如获取某新闻网站的头条信息。更有意思的是,它采用了jQuery的思想,你可以像使用jQuery一样处理页面内容,以获取你想要的页面信息。


存在的意义»

我们有时需要抓取一个网页的内容,但只需要特定部分的信息,通常会用正则来解决,这当然没有问题。正则是一个通用解决方案,但特定情况下,往往有更简单快捷的方法。比如你想查询一个编程方面的问题,当然可以使用Google,但stackoverflow作为一个专业的编程问答社区,会提供给你更多,更靠谱的答案。

对于html页面,不应该使用正则的原因主要有3个:

1、编写条件表达式比较麻烦

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

2、效率不高

对于php来说,正则应该是没有办法的办法,能通过字符串函数解决的,就不要劳烦正则了。用正则去处理一个30多k的文件,效率不敢保证。

3、有phpQuery

如果你使用过jQuery,想获取某个特定元素应该是轻而易举的事情,phpQuery让这成为了可能。

浅析phpQuery»

phpQuery是基于php5新添加的DOMDocument。而DOMDocument则是专门用来处理html/xml。它提供了强大xpath选择器及其他很多html/xml操作函数,使得处理html/xml起来非常方便。那为什么不直接使用呢?这个,去看一下官网的函数列表就知道了,如果对自己的记忆力很有信心,不妨一试。

几个简单的例子»

1、获取蓝色理想最热的招聘职位。

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()."<br>";

}

2.采集新浪网国内新闻的头条。

include 'phpQuery/phpQuery.php';

phpQuery::newDocumentFile('http://news.sina.com.cn/china');

echo pq(".blkTop h1:eq(0)")->html();

小结»

1.pq()就像jQuery里的$();

2.基本上jQuery的选择器都可以用在phpQuery上,只要把’.'变成’->’;

3.phpQuery提供了好几种载入文件的方法,有的使用字符串,有的使用文件(包括url),选择的时候要注意.

其他解析器»

simple_html_dom也是个不错的html解析器,使用起来也挺方便,是基于正则的,所以没有phpQuery那么强大。如果没有太高的要求,也基本够用了。

yql是yahoo出的一款使用类似SQL的语言,来获取相应的数据,也很强大,无须任何类库,可以直接调用,支持xpath,如果对SQL语句比较熟悉的话,可以考虑yql。


phpQuery项目下载地址http://code.google.com/p/phpquery/

新窗口打开 关闭