インターネット時代では、xml ファイルはデータの保存と送信の役割を果たします。 Soap プロトコルは Xml を介して情報を通信し、Xml ファイルなどを介してデータベースにアクセスします。では、XML ファイルから必要な情報をすばやく取得するにはどうすればよいでしょうか?
Java の JAXP と Microsoft.Net の両方に Xml パーサーがあることはわかっています。Microsoft.Net は読み取り中に分析しますが、JAXP はメモリに読み込んでから分析します (読み取り用のイベント メカニズムもあります)。速読に。これに基づいて、Microsoft.Net と JAXP の両方は、XML ファイル内で必要なノードを迅速に見つけるための XPATH メカニズムを提供します。
たとえば、booksort :
<?xml version="1.0"?> <!-- a fragment of a book store inventory database --> <bookstore xmlns:bk="urn:samples"> <book genre="novel" publicationdate="1997" bk:ISBN="1-861001-57-8"> <title>PRide And Prejudice</title> <author> <first-name>Jane</first-name> <last-name>Austen</last-name> </author> <price>24.95</price> </book> <book genre="novel" publicationdate="1992" bk:ISBN="1-861002-30-1"> <title>The Handmaid's Tale</title> <author> <first-name>Margaret</first-name> <last-name>Atwood</last-name> </author> <price>29.95</price> </book> <book genre="novel" publicationdate="1991" bk:ISBN="1-861001-57-6"> <title>Emma</title> <author> <first-name>Jane</first-name> <last-name>Austen</last-name> </author> <price>19.95</price> </book> <book genre="novel" publicationdate="1982" bk:ISBN="1-861001-45-3"> <title>Sense and Sensibility</title> <author> <first-name>Jane</first-name> <last-name>Austen</last-name> </author> <price>19.95</price> </book> </bookstore>
という XML ファイルがあります。検索が正しいことがわかります。
XPATH のいくつかの関数を使用して、単純な並べ替えや単純な操作を実装することもできます。データベース内のデータを頻繁に要約する必要がある場合は、XPATH を使用してこれを実現できます。
例:
XmlReaderSample.cs //Corelib.net/System.Xml.Xsl/XPathDocument Class //Author :Any using 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
order.xml <!--Represents a customer order--> <order> <book ISBN='10-861003-324'> <title>The Handmaid's Tale</title> <price>19.95</price> </book> <cd ISBN='2-3631-4'> <title>Americana</title> <price>16.95</price> </cd> </order>
このプログラムを実行すると、結果は次のようになります:
<?xml version="1.0"?> <!-- This file represents a fragment of a book store inventory database --> <bookstore> <book cc="dd" xmlns:bk="urn:sample" xmlns:ns="http://www.Any.com" genre="autobiography" publicationdate="1981" ISBN="1-861003-11-0"> <title>The Autobiography of Benjamin Franklin</title> <ns:author> <first-name>Benjamin</first-name> <last-name>Franklin</last-name> </ns:author> <price>8.99</price> </book> <book genre="novel" publicationdate="1967" ISBN="0-201-63361-2"> <title>The Confidence Man</title> <author> <first-name>Herman</first-name> <last-name>Melville</last-name> </author> <price>11.99</price> </book> <book genre="philosophy" publicationdate="1991" ISBN="1-861001-57-6"> <title>The Gorgias</title> <author> <name>Plato</name> </author> <price>9.99</price> </book> </bookstore>
books.xml 内のすべての価格値の合計が 30.97 であり、order.xml 内のすべての価格値の合計が 36.9 であることがわかります。 。 XPAH を通じて情報をすばやく見つけることができるだけでなく、情報に対していくつかの基本的な処理を実行することもできます。
上記は、XML ファイルから情報をすばやく見つける方法を説明するための詳細な紹介です。その他の関連コンテンツについては、PHP 中国語 Web サイト (www.php.cn) に注目してください。