phpQuery—基于jQuery的PHP实现

Query的选择器之强大是有目共睹的,phpQuery 让php也拥有了这样的能力,它就至关于服务端的jQuery。php

先来看看官方简介:html

phpQuery is a server-side, chainable, CSS3 selector driven Document Object Model (DOM) API based on jQuery JavaScript Library.jquery

Library is written in PHP5 and provides additional Command Line Interface (CLI).正则表达式

 

存在的意义

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

对于html页面,不该该使用正则的缘由主要有3个服务器

一、编写条件表达式比较麻烦 
尤为对于新手,看到一堆”不知所云”的字符评凑在一块儿,有种脑壳都要炸了的感受。若是要分离的对象没有太明显的特征,正则写起来更是麻烦。dom

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

三、有phpQuery 
若是你使用过jQuery,想获取某个特定元素应该是垂手可得的事情,phpQuery让这成为了可能。函数

 

浅析phpQuery

phpQuery是基于php5新添加的DOMDocument。而DOMDocument则是专门用来处理html/xml。它提供了强大xpath选 择器及其余不少html/xml操做函数,使得处理html/xml起来很是方便。那为何不直接使用呢?这个,去看一下官网的函数列表 就知道了,若是对本身的记忆力颇有信心, 不妨一试。google

 

几个简单的例子

 

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

 

  1. <?  

  2. include 'phpQuery.php';  

  3. phpQuery::newDocumentFile('http://job.blueidea.com');  

  4. $companies = pq('#hotcoms .coms')->find('div');  

  5. foreach($companies as $company)  

  6. {  

  7.    echo pq($company)->find('h3 a')->text()."<br>";  

  8. }  

 

小结

  • 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?

相关文章
相关标签/搜索