用phpQuery像jquery一样解析html代码

简介

如何在php中方便地解析html代码,估计是每个phper都会遇到的问题。用phpQuery就可以让php处理html代码像jQuery一样方便。

项目地址:https://code.google.com/p/phpquery/

github地址:https://github.com/TobiaszCudnik/phpquery

DEMO

下载库文件:https://code.google.com/p/phpquery/downloads/list

我下的是onefile版:phpQuery-0.9.5.386-onefile.zip

官方demo:https://code.google.com/p/phpquery/source/browse/branches/dev/demo.php

然后在项目中引用。

html文件test.html:

<div class="thumb" id="Thumb-13164-3640" style="position: absolute; left: 0px; top: 0px;">
    <a href="/Spiderman-City-Drive">
        <img src="/thumb/12/Spiderman-City-Drive.jpg" >
        <span class="GameName" id="GameName-13164-3640" style="display: none;">Spiderman City Drive</span>
        <span class="GameRating" id="GameRating-13164-3640" style="display: none;">
            <span style="width: 68.14816px;"></span>
        </span>
    </a>
</div>
<div class="thumb" id="Thumb-13169-5946" style="position: absolute; left: 190px; top: 0px;">
    <a href="/Spiderman-City-Raid">
        <img src="/thumb/12/Spiderman-City-Raid.jpg" >
        <span class="GameName" id="GameName-13169-5946" style="display: none;">Spiderman - City Raid</span>
        <span class="GameRating" id="GameRating-13169-5946" style="display: none;">
            <span style="width: 67.01152px;"></span>
        </span>
    </a>
</div>

php处理:

<?php
    include(‘phpQuery-onefile.php‘);

    $filePath = ‘test.html‘;
    $fileContent = file_get_contents($filePath);
    $doc = phpQuery::newDocumentHTML($fileContent);
    phpQuery::selectDocument($doc);
    $data = array(
        ‘name‘ => array(),
        ‘href‘ => array(),
        ‘img‘ => array()
    );
    foreach (pq(‘a‘) as $t) {
        $href = $t -> getAttribute(‘href‘);
        $data[‘href‘][] = $href;
    }
    foreach (pq(‘img‘) as $img) {
        $data[‘img‘][] = $domain . $img -> getAttribute(‘src‘);
    }
    foreach (pq(‘.GameName‘) as $name) {
        $data[‘name‘][] = $name -> nodeValue;
    }
    var_dump($data);
?>

上面的代码中包含了取属性和innerText内容(通过nodeValue取)。

输出:

array (size=3)
  ‘name‘ =>
    array (size=2)
      0 => string ‘Spiderman City Drive‘ (length=20)
      1 => string ‘Spiderman - City Raid‘ (length=21)
  ‘href‘ =>
    array (size=2)
      0 => string ‘http://www.gahe.com/Spiderman-City-Drive‘ (length=40)
      1 => string ‘http://www.gahe.com/Spiderman-City-Raid‘ (length=39)
  ‘img‘ =>
    array (size=2)
      0 => string ‘http://www.gahe.com/thumb/12/Spiderman-City-Drive.jpg‘ (length=53)
      1 => string ‘http://www.gahe.com/thumb/12/Spiderman-City-Raid.jpg‘ (length=52)

强大的是pq选择器,语法类似jQuery,很方便。

时间: 2024-10-10 19:13:23

用phpQuery像jquery一样解析html代码的相关文章

jquery JSON解析代码

jquery JSON解析说明.这里首先给出JSON字符串集,代码: var data=" { root: [ {name:'1',value:'0'}, {name:'6101',value:'西安市'}, {name:'6102',value:'铜川市'}, {name:'6103',value:'宝鸡市'}, {name:'6104',value:'咸阳市'}, {name:'6105',value:'渭南市'}, {name:'6106',value:'延安市'}, {name:'610

jQuery 插件开发解析

那么首先我们来简单的看一下最正统的 jQuery 插件定义方式: ? 1 2 3 4 5 6 7 8 9 10 11 12 (function ($) {     $.fn.插件名 = function (settings) {         //默认参数         var defaultSettings = {         }         /* 合并默认参数和用户自定义参数 */ settings = $.extend(defaultSettings, settings); r

jQuery代码开发技巧收集,jquery常用的开发代码

jQuery代码开发技巧收集,jquery常用的开发代码 今天分享一个jquery常用的开发代码,大部分是网友总结的,总共60条.后期我也会陆续完善! 把我在开发中常用的写在这里,希望持续关注~~ 1. 使用siblings()来处理同类元素 // Rather than doing this $('#nav li').click(function(){ $('#nav li').removeClass('active'); $(this).addClass('active'); }); //

jquery eval解析JSON中的注意点介绍

在JS中将JSON的字符串解析成JSON数据格式,一般有两种方式:使用eval()函数.使用Function对象来进行返回解析,下面有个示例,感兴趣的朋友可以参考下 在JS中将JSON的字符串解析成JSON数据格式,一般有两种方式: 1.一种为使用eval()函数. 2. 使用Function对象来进行返回解析. 使用eval函数来解析,并且使用jquery的each方法来遍历 用jquery解析JSON数据的方法,作为jquery异步请求的传输对象,jquery请求后返回的结果是json对象,

NET 解析HTML代码——NSoup

NET 解析HTML代码——NSoup NSoup是一个开源框架,是JSoup(Java)的.NET移植版本 1.直接用起来 NSoup.Nodes.Document htmlDoc = NSoup.NSoupClient.Parse(HTMLString); //无需实例化 NSoup的强大之处在于可以用类似js的方法来获取节点元素 通过元素类型获取元素GetElementByTag("p") NSoup.Select.Elements ele= htmlDoc.GetElement

可控制导航下拉方向的jQuery下拉菜单代码

效果:http://hovertree.com/texiao/nav/1/ 代码如下: <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>可控制导航下拉方向的jQuery下拉菜单代码 - 何问起</title> <base ta

jquery操作单选钮代码示例

jquery操作单选钮代码示例:radio单选按钮是最重要的表单元素之一,下面介绍一下常用的几个jquery对radio单选按钮操作.一.取消选中: $(".theclass").each(function(){ if($(this).attr('checked')) { $(this).attr('checked',false); } }); 以上代码可以将class属性值为theclass的被选中单选按钮取消选中.二.获取被选中的单选按钮的值: var val=$('.thecla

jQuery ajax的前台代码编写

jQuery ajax的前台代码: <script type="text/javascript" src="/include/jquery/jquery-1.1.3.1.pack.js"></script><form name="form1" id="form1" action="ajax.php?action=1" method="post">  &

jQuery禁用鼠标右键代码实例

jQuery禁用鼠标右键代码实例:很多用户可能由于某些需要,有禁止鼠标右键这么一个要求,下面就是一个能够实现此功能的代码.代码如下: $(function(){ $(document).bind("contextmenu",function(e){ return false; }) }) 以上代码实现了我们的要求,直接套用就可以了. 原文地址是:http://www.softwhy.com/forum.php?mod=viewthread&tid=13503 更多内容可以参阅: