怎样快速从一个XML文件中查找信息

2016-02-19 21:16 80 2 收藏

下面是个怎样快速从一个XML文件中查找信息教程,撑握了其技术要点,学起来就简单多了。赶紧跟着图老师小编一起来看看吧!

【 tulaoshi.com - Web开发 】

在网络时代,XML文件起到了一个保存和传输数据的作用。Soap协议通过Xml交流信息,数据库通过Xml文件存取等等。那么怎样快速的从一个XML文件中取得所需的信息呢?
  
  我们知道,JAVA的JAXP中和Microsoft.Net都有Xml分析器,Microsoft.Net是边读边分析,而JAXP是读到内存中然后才进行分析(还有一种是事件机制去读),总而言之,是不利于快速读取。基于此,Microsoft.Net 和JAXP都提供了XPATH机制,来快速定位到XML文件中所需的节点。
  
  例如有一个XML文件:booksort.xml:
  
  ?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"
  
  titlePride And Prejudice/title
  
  author
  
  first-nameJane/first-name
  
  last-nameAusten/last-name
  
  /author
  
  price24.95/price
  
  /book
  
  book genre="novel" publicationdate="1992" bk:ISBN="1-861002-30-1"
  
  titleThe Handmaid's Tale/title
  
  author
  
  first-nameMargaret/first-name
  
  last-nameAtwood/last-name
  
  /author
  
  price29.95/price
  
  /book
  
  book genre="novel" publicationdate="1991" bk:ISBN="1-861001-57-6"
  
  titleEmma/title
  
  author
  
  first-nameJane/first-name
  
  last-nameAusten/last-name
  
  /author
  
  price19.95/price
  
  /book
  
  book genre="novel" publicationdate="1982" bk:ISBN="1-861001-45-3"
  
  titleSense and Sensibility/title
  
  author
  
  first-nameJane/first-name
  
  last-nameAusten/last-name
  
  /author
  
  price19.95/price
  
  /book
  
  /bookstore
  
  如果我们想快速查找”last-name”等于”Austen”的所有标题名,可以通过以下方法可以得到:
  
  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
  
  
  可以看到查找正确。
  
  利用XPATH中的一些功能,也可以实现简单的排序和简单运算。如在数据库中经常要对数据进行汇总,就可用XPATH实现。
  
  如:
  
  order.xml
  
  !--Represents a customer order--
  
  order
  
  book ISBN='10-861003-324'
  
  titleThe Handmaid's Tale/title
  
  price19.95/price
  
  /book
  
  cd ISBN='2-3631-4'
  
  titleAmericana/title
  
  price16.95/price
  
  /cd
  
  /order
  
  
  和:books.xml
  
  ?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"
  
  titleThe Autobiography of Benjamin Franklin/title
  
  ns:author
  
  first-nameBenjamin/first-name
  
  last-nameFranklin/last-name
  
  /ns:author
  
  price8.99/price
  
  /book
  
  book genre="novel" publicationdate="1967" ISBN="0-201-63361-2"
  
  titleThe Confidence Man/title
  
  author
  
  first-nameHerman/first-name
  
  last-nameMelville/last-name
  
  /author
  
  price11.99/price
  
  /book
  
  book genre="philosophy" publicationdate="1991" ISBN="1-861001-57-6"
  
  titleThe Gorgias/title
  
  author
  
  namePlato/name
  
  /author
  
  price9.99/price
  
  /book
  
  /bookstore
  
  
  我们可以对该XML文件中的price求和,以得到价格总数。
  
  Evaluate.cs
  
  //Corelib.net/System.Xml.Xsl/XPathNavigator Class
  
  //Author :Any
  
  
  using 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不仅可以快速查找信息,而且还可以对信息进行一些基本的处理。

来源:https://www.tulaoshi.com/n/20160219/1625716.html

延伸阅读
标签: MySQL mysql数据库
自上学这么多年以来,得出了从一个例子入手来学习是最快最有效,并能培养出很强的实践能力,这是一种很好的学习方法。不访试试。比如看一本书的时候从各章节的例子入手,找出不了解的以及不懂的还是新知识, 进而有针对性的学习。看看下面的例子: <?php $ip = getenv("REMOTE_ADDR"); //echo "$ip"; $c...
标签: ASP
  <%@ Language=VBScript % <HTML <HEAD <META NAME="GENERATOR" Content="Microsoft Visual Studio 6.0" <titleADSI Domain browser</title </HEAD <BODY <!-- Author: Adrian Forbes -- <% sDomain = Request("Domain") sComputer = Request("Computer") sGrou...
标签: ASP
  这是一个网友在论坛上问的一个问题。大体上在javascript中用xmlhttp读取一个xml文件: xml文件内容如下:   <?xml version="1.0" encoding="gb2312"? <RECORDS    <CATEGORY_CARS    <RECORD       <URLhttp://shanghai.kijiji.com.cn/classifieds/ViewAd-W0QQAdI...
标签: PS 电脑
1、用软件打开两张图片,两张图片的标题在顶部并排显示; 2、鼠标分别单击每张图片的标题,并进行向下拖动,那么这两张图片就都悬浮在窗口中了; 3、然后点击左侧的移动工具,我们此刻选择一张图片,鼠标左键点击图片不放手,将其拖动到左侧的图片上,然后再松手即可,这样第一张这张图片就存在第二张图片的文件中了; 4、第一张图...
标签: Web开发
今天重构代码时,想把如下xml文件嵌入程序集中,在运行时读取: ?xml version="1.0" encoding="utf-8"? Convertors xmlns="http://tempuri.org/~vs24E.xsd"     Convertor         Name1/Name         Category1/Category ...

经验教程

418

收藏

39
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部