XPath快速解析XML
为什么要使用XPATH,上一篇博客查询越靠近下面单词,时间会越长,超过2s就不太好了,XPAth就是用来提高解析XML速度的。还可以解析html,效率也是不错的! 分别查询下列信息 代码: vcD4KPHA+PC9wPgo8cHJlIGNsYXNzPQ=="brush:sql;">?php// 详细学习可以参考w3
为什么要使用XPATH,上一篇博客查询越靠近下面单词,时间会越长,超过2s就不太好了,XPAth就是用来提高解析XML速度的。还可以解析html,效率也是不错的!
分别查询下列信息
代码:喎?http://www.2cto.com/kf/ware/vc/" target="_blank" class="keylink">vcD4KPHA+PC9wPgo8cHJlIGNsYXNzPQ=="brush:sql;">load('book.xml');
$xpath = new DOMXPATH($xml);
/*
$sql = 'xxx'; // 路径表达式
$xpath->query($sql);
*/
/*
xpath的路径表达式如何写?
xpath是从根节点到某个节点声经过的路径
*/
// 查询book.xml下面的每本书的title
// /bookstore/book/title
/*
$sql = '/bookstore/book/title';
$rs = $xpath->query($sql);
print_r($rs);
echo $rs->item(1)->nodeValue;
*/
// 查询book.xml下面book节点的下面的第2个title节点,哪来的第2个title节点? 这样写是不对的
/*
$sql = '/bookstore/book/title[2]';
$rs = $xpath->query($sql);
print_r($rs->length);
*/
// 查询bookestore下面的第2本书下面的title节点.
/*
$sql = '/bookstore/book[2]/title';
$rs = $xpath->query($sql);
print_r($rs->item(0)->nodeValue);
*/
// 查询bookstore下面的book节点并且价格>40元
/*
$sql = '/bookstore/book[price>40]/title';
$rs = $xpath->query($sql);
echo $rs->item(0)->nodeValue;
*/
// 查询侠客行的价格
// /bookstore/下面的book,且title=='侠客行'的书的价格
$sql = '/bookstore/book[title="侠客行"]/price';
$rs = $xpath->query($sql);
echo $rs->item(0)->nodeValue;
xpath如何不考虑路径的层次,来查询某个节点
比如我们刚才严格层次查询 /bookstore/book/title
现在我们加了一个,
<?php $xml = new DOMDocument('1.0','utf-8'); $xml->load('book.xml'); $xpath = new DOMXPATH($xml); $sql = '/bookstore/book[last()]/title'; $rs = $xpath->query($sql); // 只能查到书名的title //echo $rs->item(0)->nodeValue; // 思考 ,如何查询所有的title,不考虑层次关系? $sql = '/title'; // 这样不行,这样查的是根节点下的title,而根节点下没有title /* /a/b,这说明,a,b就是父子关系,而如果用/a//b,这样说明a只是b的祖先就行,忽略了层次 */ // 不分层次,查出所有的title /* $sql = '//title'; foreach($xpath->query($sql) as $v) { echo $v->nodeValue,'<br />'; } */ /* $sql = '//title[2]'; // 这样又理解成<title>a</title><title>b</title>,查询所有相邻的title节点,且第2个 foreach($xpath->query($sql) as $v) { echo $v->nodeValue,'<br />'; } */
上面是简单应用,来改善上篇博客效率问题
<?php // 接收单词并解析XML查询相应的单词 $word = isset($_GET['word'])?trim($_GET['word']):''; if(empty($word)) { exit('你想查啥?'); } // 解析XML并查询 $xml = new DOMDocument('1.0','utf-8'); $xml->load('./dict.xml'); /* $namelist = $xml->getElementsByTagName('name'); $isfind = false; foreach($namelist as $v) { if($v->nodeValue == $word) { //print_r($v); echo $word,'<br />'; echo '意思:',$v->nextSibling->nodeValue,'<br />'; echo '例句:',$v->nextSibling->nextSibling->nodeValue,'<br />'; $isfind = true; break; } } if(!$isfind) { echo 'sorry'; } */ // 接下来用xpath来查询词典 $xpath = new DOMXpath($xml); // 查询/dict下的word,且name=$word的节点下面的/name节点 $sql = '/dict/word[name="' . $word . '"]/name'; //echo $sql; $words = $xpath->query($sql); if($words->length == 0) { echo 'sorry'; exit; } // 查到了 $name = $words->item(0); echo $word,'<br />'; echo '意思:',$name->nextSibling->nodeValue,'<br />'; echo '例句:',$name->nextSibling->nextSibling->nodeValue,'<br />';
来解析一下的html
<?php /*** ====笔记部分==== xpath是根据DOM标准来查询, html也是DOM, 也能查,岂只是xml ***/ $html = new DOMDocument('1.0','utf-8'); $html->loadhtmlfile('dict.html'); $xpath = new DOMXPATH($html); $sql = '/html/body/h2'; echo $xpath->query($sql)->item(0)->nodeValue,'<br />'; // 查询id="abc"的div节点 $sql = '//div[@id="abc"]'; echo $xpath->query($sql)->item(0)->nodeValue; // 分析第2个/div/下的p下的相邻span的第2个span的内容 $sql = '//div/p/span[2]'; echo $xpath->query($sql)->item(0)->nodeValue;

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

直接從數據庫中恢復被刪除的行通常是不可能的,除非有備份或事務回滾機制。關鍵點:事務回滾:在事務未提交前執行ROLLBACK可恢復數據。備份:定期備份數據庫可用於快速恢復數據。數據庫快照:可創建數據庫只讀副本,在數據誤刪後恢復數據。慎用DELETE語句:仔細檢查條件,避免誤刪數據。使用WHERE子句:明確指定要刪除的數據。使用測試環境:在執行DELETE操作前進行測試。

直接通過 Navicat 查看 MongoDB 密碼是不可能的,因為它以哈希值形式存儲。取回丟失密碼的方法:1. 重置密碼;2. 檢查配置文件(可能包含哈希值);3. 檢查代碼(可能硬編碼密碼)。

優雅安裝 MySQL 的關鍵在於添加 MySQL 官方倉庫。具體步驟如下:下載 MySQL 官方 GPG 密鑰,防止釣魚攻擊。添加 MySQL 倉庫文件:rpm -Uvh https://dev.mysql.com/get/mysql80-community-release-el7-3.noarch.rpm更新 yum 倉庫緩存:yum update安裝 MySQL:yum install mysql-server啟動 MySQL 服務:systemctl start mysqld設置開機自啟動

CentOS將於2024年停止維護,原因是其上游發行版RHEL 8已停止維護。該停更將影響CentOS 8系統,使其無法繼續接收更新。用戶應規劃遷移,建議選項包括CentOS Stream、AlmaLinux和Rocky Linux,以保持系統安全和穩定。

您想了解如何在父分類存檔頁面上顯示子分類嗎?在自定義分類存檔頁面時,您可能需要執行此操作,以使其對訪問者更有用。在本文中,我們將向您展示如何在父分類存檔頁面上輕鬆顯示子分類。為什麼在父分類存檔頁面上顯示子分類?通過在父分類存檔頁面上顯示所有子分類,您可以使其不那麼通用,對訪問者更有用。例如,如果您運行一個關於書籍的WordPress博客,並且有一個名為“主題”的分類法,那麼您可以添加“小說”、“非小說”等子分類法,以便您的讀者可以

Oracle SQL語句的核心是SELECT、INSERT、UPDATE和DELETE,以及各種子句的靈活運用。理解語句背後的執行機制至關重要,如索引優化。高級用法包括子查詢、連接查詢、分析函數和PL/SQL。常見錯誤包括語法錯誤、性能問題和數據一致性問題。性能優化最佳實踐涉及使用適當的索引、避免使用SELECT *、優化WHERE子句和使用綁定變量。掌握Oracle SQL需要實踐,包括代碼編寫、調試、思考和理解底層機制。

Navicat連接超時原因:網絡不穩定、數據庫繁忙、防火牆阻攔、服務器配置問題、Navicat設置不當。解決步驟:檢查網絡連接、數據庫狀況、防火牆設置,調整服務器配置,檢查Navicat設置,重啟軟件和服務器,聯繫管理員尋求幫助。

從Navicat直接查看PostgreSQL密碼是不可能的,因為Navicat出於安全原因對密碼進行了加密存儲。若要確認密碼,嘗試連接數據庫;要修改密碼,請使用psql或Navicat的圖形界面;其他目的需在代碼中配置連接參數,避免硬編碼密碼。為增強安全性,建議使用強密碼、定期修改和啟用多因素認證。
