Xslt 将具有相同名称的移动节点转换为其父节点
要转换的文档大致如下所示:Xslt 将具有相同名称的移动节点转换为其父节点,xslt,Xslt,要转换的文档大致如下所示: <?xml version="1.0" encoding="utf-8"?> <root> <someCatalogProp>ąć</someCatalogProp> <meanProp> <node id="1"> <someProperty>blabla1</someProperty> <children>
<?xml version="1.0" encoding="utf-8"?>
<root>
<someCatalogProp>ąć</someCatalogProp>
<meanProp>
<node id="1">
<someProperty>blabla1</someProperty>
<children>
<node idref="2"/>
</children>
</node>
<node id="2">
<someProperty>blabla2</someProperty>
<children>
<node idref="3"/>
</children>
</node>
</meanProp>
<node id="1">
<someProperty>blabla1</someProperty>
<children>
<node idref="2"/>
</children>
</node>
<node id="2">
<someProperty>blabla2</someProperty>
<children>
<node idref="3"/>
</children>
</node>
<node id="3">
<someProperty>blabla3</someProperty>
<children>
</children>
</node>
</root>
<root>
<someCatalogProp>ąć</someCatalogProp>
<node id = "1">
<someProperty>blabla1</someProperty>
<children>
<node id = "2">
<someProperty>blabla2</someProperty>
<children>
<node id = "3">
<someProperty>blabla2</someProperty>
<children>
</children>
</node>
</children>
</node>
</children>
</node>
</root>
ąć
无稽之谈
无稽之谈
无稽之谈
无稽之谈
喋喋不休
结果文档应如下所示:
<?xml version="1.0" encoding="utf-8"?>
<root>
<someCatalogProp>ąć</someCatalogProp>
<meanProp>
<node id="1">
<someProperty>blabla1</someProperty>
<children>
<node idref="2"/>
</children>
</node>
<node id="2">
<someProperty>blabla2</someProperty>
<children>
<node idref="3"/>
</children>
</node>
</meanProp>
<node id="1">
<someProperty>blabla1</someProperty>
<children>
<node idref="2"/>
</children>
</node>
<node id="2">
<someProperty>blabla2</someProperty>
<children>
<node idref="3"/>
</children>
</node>
<node id="3">
<someProperty>blabla3</someProperty>
<children>
</children>
</node>
</root>
<root>
<someCatalogProp>ąć</someCatalogProp>
<node id = "1">
<someProperty>blabla1</someProperty>
<children>
<node id = "2">
<someProperty>blabla2</someProperty>
<children>
<node id = "3">
<someProperty>blabla2</someProperty>
<children>
</children>
</node>
</children>
</node>
</children>
</node>
</root>
ąć
无稽之谈
无稽之谈
无稽之谈
子项的数量可以是多个。层次结构的深度不受限制
转换xslt看起来如何?
提前谢谢。使用实际上很容易做到这一点 如果您有格式良好的输入,例如: XML
<root>
<node id="1">
<someProperty>blabla1</someProperty>
<children>
<node idref="2"/>
</children>
</node>
<node id="2">
<someProperty>blabla2</someProperty>
<children>
<node idref="3"/>
</children>
</node>
<node id="3">
<someProperty>blabla2</someProperty>
<children>
</children>
</node>
</root>
无稽之谈
无稽之谈
无稽之谈
应用以下样式表:
XSLT1.0
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes"/>
<xsl:strip-space elements="*"/>
<xsl:key name="child" match="node" use="@id" />
<xsl:key name="parent" match="node" use="@idref" />
<!-- identity transform -->
<xsl:template match="@*|node()">
<xsl:copy>
<xsl:apply-templates select="@*|node()"/>
</xsl:copy>
</xsl:template>
<xsl:template match="/root">
<xsl:copy>
<xsl:apply-templates select="node[not(key('parent', @id))]"/>
</xsl:copy>
</xsl:template>
<xsl:template match="node[@idref]">
<xsl:apply-templates select="key('child', @idref)"/>
</xsl:template>
</xsl:stylesheet>
将产生:
结果
<?xml version="1.0" encoding="UTF-8"?>
<root>
<node id="1">
<someProperty>blabla1</someProperty>
<children>
<node id="2">
<someProperty>blabla2</someProperty>
<children>
<node id="3">
<someProperty>blabla2</someProperty>
<children/>
</node>
</children>
</node>
</children>
</node>
</root>
无稽之谈
无稽之谈
无稽之谈
当根级别下存在其他标记时,我会得到非常“随机”的结果,但是,例如,在node id=“1”上方有一个ABP。请编辑您的问题并提供一个具有代表性(且格式良好)的输入示例。我没有看到任何“随机”结果。输出中缺少someCatalogProp
节点,仅此而已。如果您想包含它,可以将
添加到模板匹配根
。我有一些随机结果,文件较大,因为有时会出现节点级别的其他节点,有时不依赖于测试数据。我怎样才能一般地指定,如果有超过个标记而不是一些catalologprop,一些在节点之前,一些在节点之后呢?我是否可以以某种方式保留其他结构并只处理“node”元素?您可以执行
。要保留原始顺序,请将两者结合起来:
。这是您的新示例:为什么输出中没有meanProp
节点?另外,您有多个具有相同id的节点元素-这是非常有问题的,并且您的输出没有提供如何处理它的线索。