婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > PHP xpath提取網頁數據內容代碼解析

PHP xpath提取網頁數據內容代碼解析

熱門標簽:如何在世界地圖標注 梧州市機器人外呼系統怎么樣 地圖標注符號樣式有 公司外呼系統中心 臨沂crm外呼系統平臺 天客通地圖標注 菏澤語音外呼系統運營商 電子地圖標注怎么修改 廈門400電話辦理選易號網

想要使用xpath來解析html內容, PHP自帶兩個對象

DOMDocument,DOMXpath,其中初始化 loadHtml一般都會報很多警告,但是并不影響使用,用@屏蔽錯誤。

  /**
   * 初始化DOMXpath對象
   *
   * @param [type] $content 網頁內容
   * @param [array] $pathinfo 匹配信息
   *
   * @return void
   */
  private function _createXpathObj($content, $patinfo)
  {
    // 如果沒有xpath配置項,不初始化xpath
    if (!$this->_existsXpathParse($patinfo)) {
      return;
    }
    try {
      $dom = new \DOMDocument();
      @$dom->loadHtml($content);
      $dom->normalize();
      $xpath = new \DOMXpath($dom);
      $this->xpathObj = $xpath;
    } catch (\Exception $e) {
      getService('logger')->warning('Parse html fail', ['content' => $content]);
    }
  }

其中 $node 為 DOMElement 對象。

  /**
   * 獲取Xpath解析值
   *
   * @param [type] $pat 匹配模式
   *
   * @return string
   */
  private function _getXpathField($pat)
  {
    $objs = $this->xpathObj->query($pat);
    if ($objs->length > 0) {
      $node = $objs->item(0);
      $outerHTML = $node->ownerDocument->saveHTML($node);
      return trim($outerHTML);
      # 作為示例 輸出innerhtml
      //$innerHTML = '';
      //foreach ($node->childNodes as $childNode){
      //   $innerHTML .= $childNode->ownerDocument->saveHTML($childNode);
      //}
      //return $innerHTML; 
      # 作為示例 輸出文本不含標簽
      //return $node->textContent; //$node->nodeValue;
    }
    return '';
  }

示例

?php
    $dom = new DOMDocument('1.0','UTF-8');
    $dom->loadHTML('html>body>div>p>p1/p>p>p2/p>/div>/body>/html>');    
    $node = $dom->getElementsByTagName('div')->item(0);    
    $outerHTML = $node->ownerDocument->saveHTML($node);    
    $innerHTML = '';
    foreach ($node->childNodes as $childNode){
        $innerHTML .= $childNode->ownerDocument->saveHTML($childNode);
    }
    echo 'h2>outerHTML: /h2>';
    echo htmlspecialchars($outerHTML);
    echo 'h2>innerHTML: /h2>';
    echo htmlspecialchars($innerHTML);    
?>

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • PHP操作XML中XPath的應用示例
  • php用xpath解析html的代碼實例講解
  • PHP xpath()函數講解
  • PHP registerXPathNamespace()函數講解
  • PHP使用xpath解析XML的方法詳解
  • php+xml編程之xpath的應用實例
  • php XPath對XML文件查找及修改實現代碼

標簽:迪慶 瀘州 貴陽 郴州 黃石 白城 雞西 綿陽

巨人網絡通訊聲明:本文標題《PHP xpath提取網頁數據內容代碼解析》,本文關鍵詞  PHP,xpath,提取,網頁,數據,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《PHP xpath提取網頁數據內容代碼解析》相關的同類信息!
  • 本頁收集關于PHP xpath提取網頁數據內容代碼解析的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 囊谦县| 霍城县| 安多县| 罗定市| 西城区| 闸北区| 四川省| 垣曲县| 苍溪县| 横山县| 陕西省| 商都县| 吉水县| 西青区| 沂水县| 商水县| 林甸县| 顺平县| 鄱阳县| 建湖县| 寻乌县| 盖州市| 花莲县| 易门县| 香河县| 巫溪县| 桃源县| 舟曲县| 中方县| 柘荣县| 教育| 安庆市| 克山县| 吉安县| 丽水市| 高雄县| 武乡县| 秦皇岛市| 马龙县| 会泽县| 秦安县|