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

Xslt 将动态xml节点映射到静态节点,xslt,Xslt,我正在寻找一个人来帮助解决一个看似简单的问题。 我想将/fields[x]/message\u id的节点映射到列表中5个条目的静态节点/MessageID0x。 源节点是可选的,可能不存在。 模式如下所示 我希望,我只是没有看到显而易见的东西 来源定义为: <xs:element name="fields"> <xs:complexType> <xs:sequence> <xs:element name=

我正在寻找一个人来帮助解决一个看似简单的问题。 我想将/fields[x]/message\u 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"/>

目标定义为:

<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"/>

==来自===========

<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>
<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>

2019年11月12日至17日
好啊
2019-11-12T16:16:01
2019-11-12T17:16:01.771Z
0
1.
科奇努AX2
lid://infor.landmark.lmrkmt/15d8f834-7680-541e-0000-001d5dae3e7b
科奇努AX2
lid://infor.landmark.lmrkmt/0535a86a-7680-1868-0000-07625db833c1
科奇努AX2
lid://infor.landmark.lmrkmt/0535a86a-7680-1864-0000-03445db849c8
科奇努AX2
lid://infor.landmark.lmrkmt/0535a86a-7680-1867-0000-01151db125c8
到===================

<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>
<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>

2019年11月12日至17日
好啊
2019-11-12T16:16:01
2019-11-12T17:16:01.771Z
0
1.
lid://infor.landmark.lmrkmt/15d8f834-7680-541e-0000-001d5dae3e7b
lid://infor.landmark.lmrkmt/0535a86a-7680-1868-0000-07625db833c1
lid://infor.landmark.lmrkmt/0535a86a-7680-1868-0000-07625db833c8
lid://infor.landmark.lmrkmt/15d8f834-1864-3322-0000-03445db125c8
lid://infor.landmark.lmrkmt/15d8f834-7680-1867-0000-01151db125g4

我相信,只要做以下事情,就可以达到要求的结果:

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

<!-- 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>

2019年11月12日至17日
好啊
2019-11-12T16:16:01
2019-11-12T17:16:01.771Z
0
1.
lid://infor.landmark.lmrkmt/15d8f834-7680-541e-0000-001d5dae3e7b
lid://infor.landmark.lmrkmt/0535a86a-7680-1868-0000-07625db833c1
lid://infor.landmark.lmrkmt/0535a86a-7680-1864-0000-03445db849c8
lid://infor.landmark.lmrkmt/0535a86a-7680-1867-0000-01151db125c8
这与你展示的结果不同——尽管如此,我怀疑这是正确的结果



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

那么在示例输出中不应该有
元素,对吗?您真的确定必须这样做吗?做类似is的事情通常被认为是不好的做法,因为这意味着改变模式只是为了将来添加另一个元素,maximun可以是5,但它是可选的,这意味着可以是0到5。我完全理解您的场景,但如果仅提供4个输入元素,则您的输出结果不能包括
。当您可以简单地执行
并将
字段/message\u id
转换为
MessageID
时,您定义
的具体原因是什么?每次我看到您这样做都是因为输出使用者将Xml解析为文本而不是处理Xml。好吧,假设我可以根据您的建议修改xsd,我如何获得结果?