XML文档搜索使用小结2

日期: 2008-06-18 作者:郁郁小蝎 来源:TechTarget中国

   这个方法要求我们一层层向内找我们需要的数据,如果层次很多的话,做起来就会很费劲,也容易出错。幸好.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″ http://www.w3.org/1999/XSL/Transform”>http://www.w3.org/1999/XSL/Transform” http://www.w3.org/1999/XSL/Format”>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/
  < /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 = 你所需要输给的变量


  也就是说对于类似../FTP_Magazine/FTP_Issue/这样的节点,在我们查找以前,我们需要定义一个XmlNamespaceManager,用它我们就可以找到我们所需要的节点。

我们一直都在努力坚持原创.......请不要一声不吭,就悄悄拿走。

我原创,你原创,我们的内容世界才会更加精彩!

【所有原创内容版权均属TechTarget,欢迎大家转发分享。但未经授权,严禁任何媒体(平面媒体、网络媒体、自媒体等)以及微信公众号复制、转载、摘编或以其他方式进行使用。】

微信公众号

TechTarget微信公众号二维码

TechTarget

官方微博

TechTarget中国官方微博二维码

TechTarget中国

电子邮件地址不会被公开。 必填项已用*标注

敬请读者发表评论,本站保留删除与本文无关和不雅评论的权力。

相关推荐

  • Oracle Hyperion 11.1.2.1 迁移特性与问题

    Oracle Hyperion 11.1.2.1包含可以简化移植的新工具,它们在很多情况下能够减少操作步骤。但还是有诸如Essbase Studio的一些问题必须在以后的版本中进行修复。

  • SQL Server 数据访问策略:CLR

    CLR在很大程度上解放了TSQL逻辑运算能力不足的问题,而且CLR拥有丰富的语言支持,C#,VB.NET等;在.Net Framework基础上,拥有复杂的过程逻辑和计算。

  • 在Oracle数据库中使用XML数据获取业务信息

    只需要通过从一个XML表中提取数据,我们就能发送XML格式化的采购订单给下游使用,这与需要更多转换步骤的多个关系型表才能实现形成明显对比。

  • 详解如何将关系型数据发布为XML

    抽取是通过使用XMLType视图实现的,本质上是物化为SQL执行的一个存储查询结果。XMLType视图允许文档为中心的应用程序把底层的关系结构查询为虚拟的XML文档。