这个方法要求我们一层层向内找我们需要的数据,如果层次很多的话,做起来就会很费劲,也容易出错。幸好.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中国
作者
相关推荐
-
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文档。