[英]XSLT; parse escaped text to a node-set and extract subelements
我整天都在与这个问题作斗争,并且快要结束了。
我有一个XML文件,其中某些数据部分作为转义文本存储,但它们本身是格式正确的XML。 我想将这个文本节点中的整个层次结构转换为一个节点集,并在其中提取数据。 我不能想到变量和函数的组合。
我希望它起作用的方式是:
<xsl:variable name="a" select="InnerXML">
<xsl:for-each select="exsl:node-set($a)/*">
'do something
</xsl:for-each>
输入元素InnerXML包含以下格式的文本
<root><elementa>text</elementa><elementb><elementc/><elementd>text</elementd></elementb></root>
但这并不重要。 我只想像普通节点集一样浏览xml。
我要去哪里错了?
如果您可以使用Saxon 9.x ,它会提供saxon:parse()扩展函数来解决此任务。
我所做的是在xslt中有一个msxsl脚本(这是在Windows .NET环境中):
<msxsl:script implements-prefix="cs" language="C#" >
<![CDATA[
public XPathNodeIterator parse(String strXML)
{
System.IO.StringReader rdr = new System.IO.StringReader(strXML);
XPathDocument doc = new XPathDocument(rdr);
XPathNavigator nav = doc.CreateNavigator();
XPathExpression expr;
expr = nav.Compile("/");
XPathNodeIterator iterator = nav.Select(expr);
return iterator;
}
]]>
</msxsl:script>
那么您可以这样称呼它:
<xsl:variable name="itemHtml" select="cs:parse(EscapedNode)" />
现在该变量包含xml,您可以迭代通过
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.