将动态xml节点映射到静态节点

时间:2019-11-13 11:29:37

标签: xslt

我正在寻找可以帮助您解决看似简单的问题的人。 我想将/ fields [x] / message_id的节点映射到列表中5个条目的静态节点/ MessageID0x。 源节点是可选的,可能不存在。 架构如下 我希望我看不到明显的东西。

来源定义为:

<xs:element name="fields">
    <xs:complexType>
        <xs:sequence>
            <xs:element name="tenant_id" type="xs:normalizedString" minOccurs="0"/>
            <xs:element name="message_id" type="xs:normalizedString" minOccurs="0"/>

目标定义为:

<xs:element name="MessageID01" type="xs:normalizedString" minOccurs="0"/>
<xs:element name="MessageID02" type="xs:normalizedString" minOccurs="0"/>
<xs:element name="MessageID03" type="xs:normalizedString" minOccurs="0"/>
<xs:element name="MessageID04" type="xs:normalizedString" minOccurs="0"/>
<xs:element name="MessageID05" type="xs:normalizedString" minOccurs="0"/>

=== FROM ===========

<root>
<ID>2019Nov12_17</ID>
<PingResult>OK</PingResult>
<StartDateTime>2019-11-12T16:16:01</StartDateTime>
<EndDateTime>2019-11-12T17:16:01.771Z</EndDateTime>
<start>0</start>
<numFound>1</numFound>
<fields>
    <tenant_id>KOCHIND_AX2</tenant_id>
    <message_id>lid://infor.landmark.lmrkmt/15d8f834-7680-541e-0000-001d5dae3e7b</message_id>
</fields>
<fields>
    <tenant_id>KOCHIND_AX2</tenant_id>
    <message_id>lid://infor.landmark.lmrkmt/0535a86a-7680-1868-0000-07625db833c1</message_id>
</fields>
<fields>
    <tenant_id>KOCHIND_AX2</tenant_id>
    <message_id>lid://infor.landmark.lmrkmt/0535a86a-7680-1864-0000-03445db849c8</message_id>
</fields>
<fields>    
    <tenant_id>KOCHIND_AX2</tenant_id>
    <message_id>lid://infor.landmark.lmrkmt/0535a86a-7680-1867-0000-01151db125c8</message_id>
</fields>
</root>

TO ==================

<root>
<ID>2019Nov12_17</ID>
<PingResult>OK</PingResult>
<StartDateTime>2019-11-12T16:16:01</StartDateTime>
<EndDateTime>2019-11-12T17:16:01.771Z</EndDateTime>
<start>0</start>
<numFound>1</numFound>
<MessageID01>lid://infor.landmark.lmrkmt/15d8f834-7680-541e-0000-001d5dae3e7b</MessageID01>
<MessageID02>lid://infor.landmark.lmrkmt/0535a86a-7680-1868-0000-07625db833c1</MessageID02>
<MessageID03>lid://infor.landmark.lmrkmt/0535a86a-7680-1868-0000-07625db833c8</MessageID03>
<MessageID04>lid://infor.landmark.lmrkmt/15d8f834-1864—3322-0000-03445db125c8</MessageID04>
<MessageID05>lid://infor.landmark.lmrkmt/15d8f834-7680-1867-0000-01151db125g4</MessageID05>
</root>

1 个答案:

答案 0 :(得分:0)

我相信通过以下操作可以简单地实现所要求的结果:

XSLT 1.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="*"/>

<!-- identity transform -->
<xsl:template match="@*|node()">
    <xsl:copy>
        <xsl:apply-templates select="@*|node()"/>
    </xsl:copy>
</xsl:template>

<xsl:template match="fields">
    <xsl:variable name="n">
        <xsl:number format="01"/>
    </xsl:variable>
    <xsl:element name="MessageID{$n}">
        <xsl:value-of select="message_id"/>
    </xsl:element>
</xsl:template>

</xsl:stylesheet>

转换示例输入的结果将是:

<?xml version=\"1.0\" encoding=\"UTF-8\"?>
<root>
  <ID>2019Nov12_17</ID>
  <PingResult>OK</PingResult>
  <StartDateTime>2019-11-12T16:16:01</StartDateTime>
  <EndDateTime>2019-11-12T17:16:01.771Z</EndDateTime>
  <start>0</start>
  <numFound>1</numFound>
  <MessageID01>lid://infor.landmark.lmrkmt/15d8f834-7680-541e-0000-001d5dae3e7b</MessageID01>
  <MessageID02>lid://infor.landmark.lmrkmt/0535a86a-7680-1868-0000-07625db833c1</MessageID02>
  <MessageID03>lid://infor.landmark.lmrkmt/0535a86a-7680-1864-0000-03445db849c8</MessageID03>
  <MessageID04>lid://infor.landmark.lmrkmt/0535a86a-7680-1867-0000-01151db125c8</MessageID04>
</root>

与您显示的结果不同-尽管如此,我怀疑它是正确的。


请注意,按名称为同级节点编号是不好的做法。这使得后续的转换更加困难。如果您需要一个数字(尽管我不知道为什么要这么做),请使用属性。