大家在.NET中处理XML文档的时候,经常会需要找到文档中的某个节点的数据。要找到某个节点,有许多种方法,在这里我就把几种常用的方法给大家总结一下。

  首先,我们要做的是要把一个XML文档装入到一个XmlDocument对象中去。

  先引用几个名字空间:

  using System.Xml;
  using System.Xml.Xsl;
  using System.Xml.XPath;

  这几个名字空间大家根据名字就知道它的意思了,我就不在这儿多说了。然后就是装入XML文件的代码,方法如下:

  String xmlfile="c:/member.xml"; //其中的xmlfile是你要载入的XML文件的路径。
  XmlDocument myDoc = new XmlDocument(); //定义一个XmlDocument对象。
  myDoc.Load(xmlfile);

  
  这样,我们就有一个叫myDoc的XML文档。我们现在就来找这个文档中的一些节点。我们先来看这个XML文件的内容。
  <?xml version="1.0" encoding="UTF-8"?>
  <members>
   <member>
   <name>Tim</name>
   <hobby>reading</hobby>
   <homepage>www.aspcool.com</homepage>
   </member>
   <member>
   <name>Sandy</name>
   <hobby>learning</hobby>
   </member>
   <member>
   <name>Shally</name>
   <hobby>tranlating</hobby>
   </member>
   <member>
   <name>Christine</name>
   <hobby>working</hobby>
   </member>
  </members>

  我们现在可以用下面的方法找到name为tim的节点:
  myDoc.ChildNodes.Item(1).ChildNodes.Item(0).FirstChild.InnerText

  这个方法要求我们一层层向内找我们需要的数据,如果层次很多的话,做起来就会很费劲,也容易出错。幸好.NET给我们提供了另外一个方法SelectSingleNode和SelectNodes方法可以让我们直接找到所要的数据。比如,我们要找姓名为“Tim”的用户的hobby,我们可以用下面的方法:
  myDoc.SelectSingleNode ("//member[name='Tim']").ChildNodes.Item(1).InnerText

  其中//代表里面任意层的子节点。这样我们就可以很快的找到所要的东西。SelectSingleNode是找到一个单一的节点,SelectNodes可以找到许多节点。

  在XML中寻找某个子节点,大家都知道怎么做了,我们现在在一个特殊的XML文件---XSL文件中去找一个子节点,这个应该怎么实现呢?

  假设我现在有一个这样的XSL文件:
  <?xml version="1.0" encoding="gb2312"?>
  <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:fo="http://www.w3.org/1999/XSL/Format">
   <xsl:preserve-space elements="codes"/>
   <xsl:template match="/">
   <xsl:apply-templates/>
   </xsl:template>

   <xsl:template match="image">
   <table align="{@location}">
   <tr>
   <td>
   <img align="{@location}" alt="{text()}">
   <xsl:attribute name="src">../FTP_Magazine/FTP_Issue/<xsl:value-of select="@url"/></xsl:attribute>
   </img>
   </td>
   </tr>
   <tr>
   <td>
   <center>
   <xsl:apply-templates/>
   </center>
   </td>
   </tr>
   </table>
   </xsl:template>

  </xsl:stylesheet>

  我们在asp.net中有两个变量,我们需要XSL文件在Transform XML文件的时候采用这两个变量。我们该如何去做呢?

  我所采取的方法是先把XSL文件作为XML Document装载进来,在使用之前,我们找到需要修改的节点,用我们的变量对其进行修改。这个时候我们查找这个节点的时候需要做些变动,代码如下:

  XmlNamespaceManager nsmanager = new XmlNamespaceManager(xslDoc.NameTable);
  nsmanager.AddNamespace("xsl", "http://www.w3.org/1999/XSL/Transform");
  xslDoc.SelectSingleNode("//xsl:attribute[@name='src']", nsmanager).InnerXml = 你所需要输给的变量

  也就是说对于类似<xsl:attribute name="src">../FTP_Magazine/FTP_Issue/<xsl:value-of select="@url"/></xsl:attribute>这样的节点,在我们查找以前,我们需要定义一个XmlNamespaceManager,用它我们就可以找到我们所需要的节点。
标签:
|XM|ML|L文|文档|档搜|搜索|索使|使用|用小|小结|结|

免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
白云城资源网 Copyright www.dyhadc.com

评论“XML文档搜索使用小结”

暂无“XML文档搜索使用小结”评论...

《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线

暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。

艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。

《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。