怎樣快速從一個XML檔案中查詢資訊(轉)
在網路時代,XML檔案起到了一個儲存和傳輸資料的作用。Soap協議透過Xml交流資訊,資料庫透過Xml檔案存取等等。那麼怎樣快速的從一個XML檔案中取得所需的資訊呢?我們知道,JAVA的JAXP中和Microsoft.Net都有Xml分析器,Microsoft.Net是邊讀邊分析,而JAXP是讀到記憶體中然後才進行分析(還有一種是事件機制去讀),總而言之,是不利於快速讀取。基於此,Microsoft.Net 和JAXP都提供了XPATH機制,來快速定位到XML檔案中所需的節點。
例如有一個XML檔案:booksort.xml:
<!-- a fragment of a book store inventory database -->
如果我們想快速查詢”last-name”等於”Austen”的所有標題名,可以透過以下方法可以得到:
XmlReaderSample.cs//Corelib.net/System.Xml.Xsl/XPathDocument Class//Author :Anyusing System;using System.IO;using System.Xml;using System.Xml.XPath;public class XmlReaderSample{public static void Main(){XmlTextReader myxtreader = new XmlTextReader("booksort.xml");XmlReader myxreader = myxtreader;XPathDocument doc = new XPathDocument(myxreader);XPathNavigator nav = doc.CreateNavigator();XPathExpression expr;expr = nav.Compile("descendant::book[author/last-name='Austen']");//expr.AddSort("title", XmlSortOrder.Ascending, XmlCaseOrder.None, "", XmlDataType.Text);XPathNodeIterator iterator = nav.Select(expr);while (iterator.MoveNext()){XPathNavigator nav2 = iterator.Current;nav2.MoveToFirstChild();Console.WriteLine("Book title: {0}", nav2.Value);}}}
執行這個程式,結果為:
Book title: Pride And Prejudice
Book title: Emma
Book title: Sense and Sensibility
可以看到查詢正確。
利用XPATH中的一些功能,也可以實現簡單的排序和簡單運算。如在資料庫中經常要對資料進行彙總,就可用XPATH實現。
如:
order.xml
<!--Represents a customer order-->
和:books.xml
<!-- This file represents a fragment of a book store inventory database -->
我們可以對該XML檔案中的price求和,以得到價格總數。
Evaluate.cs//Corelib.net/System.Xml.Xsl/XPathNavigator Class//Author :Anyusing System;using System.IO;using System.Xml;using System.Xml.XPath;public class EvaluateSample{public static void Main(){EvaluateSample myEvaluateSample = new EvaluateSample();myEvaluateSample.test("books.xml");}public void test(String args){try{//test Evaluate(String);XPathDocument myXPathDocument = new XPathDocument(args);XPathNavigator myXPathNavigator = myXPathDocument.CreateNavigator();Console.WriteLine(myXPathNavigator.Evaluate("sum(descendant::book/price)"));//testEvaluate(XPathExpression);XmlDocument doc = new XmlDocument();doc.Load("order.xml");XPathNavigator nav = doc.CreateNavigator();XPathExpression expr = nav.Compile("sum(//price/text())");Console.WriteLine(nav.Evaluate(expr));//testEvaluate(XPathExpression);XPathNodeIterator myXPathNodeIterator = nav.Select("descendant::book/title");expr = nav.Compile("sum(//price/text())");Console.WriteLine(nav.Evaluate(expr,myXPathNodeIterator));}catch (Exception e){Console.WriteLine ("Exception: {0}", e.ToString());}}}
執行這個程式,結果如下:
30.97
36.9
36.9
我們可以看到,30.97是books.xml中所有price值的總和,而36.9則是order.xml中所有price值的總和。透過XPAH不僅可以快速查詢資訊,而且還可以對資訊進行一些基本的處理。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/10752019/viewspace-950309/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- mybatis xml 檔案中like模糊查詢MyBatisXML
- Sql server:從XML檔案中讀取配置資訊SQLServerXML
- ICP域名備案查詢 分享一個可以快速批次查詢域名備案資訊的平臺
- 如何在Linux中查詢一個檔案Linux
- 如何在 Linux 中查詢一個檔案Linux
- 查詢檔案中的控制字元(轉)字元
- 快速查詢檔案(轉)
- 一個最簡單的XML檔案(轉)XML
- 怎樣結構化xml檔案到下列樣式?XML
- 想要批次查詢快遞,怎麼操作可以一鍵快速查詢物流資訊
- 幾個Linux中檔案查詢常用技術和方法(轉)Linux
- mysql 從一個表中查詢,插入到另一個表中MySql
- 像Windows 一樣地查詢 (轉)Windows
- mac誤刪檔案怎樣快速找回?Mac
- 怎樣查詢一個表的最後更新時間?
- 教你一個快速查詢批量檔案的好方法
- 檔案內容查詢命令(轉)
- 查詢jar中的pom檔案JAR
- Windows XP 中查詢驅動程式資訊(轉)Windows
- 怎樣把Oracle查詢轉換為SQL ServerOracleSQLServer
- 如何在 Linux 中查詢最大的 10 個檔案Linux
- 查詢含特定字串的檔案 (轉)字串
- 【轉】linux查詢目錄下的所有檔案中是否含有某個字串Linux字串
- Golang仿雲盤專案-2.2 檔案查詢資訊介面Golang
- 檔案批次查詢複製匯出,按檔名批次查詢檔案,按檔案內容批次查詢檔案
- Flask中怎樣返回html檔案?FlaskHTML
- 水煮orale22——查詢表空間使用資訊以及表空間中的每個資料檔案資訊
- 怎樣設定一個檔案來作為 linux 的轉換空間?(轉)Linux
- centos vim怎麼查詢檔案內容CentOS
- Structs的配置檔案都在一個檔案(struct-config.xml)中嗎?StructXML
- 從oracle v$version檢視中查詢os的資訊Oracle
- Mac系統怎麼快速查詢大檔案?Mac
- 快遞到哪了怎麼查詢?有上百單怎麼樣可以快速查詢?
- 從一個MysqL的例子來學習查詢語句(轉)MySql
- 一個免費的 Whois 資訊查詢介面
- 使用 lsof 查詢開啟的檔案(轉)
- Linux檔案查詢技術大全(轉)Linux
- Linux檔案內容查詢命令(轉)Linux