使用XSLT将xml拆分为使用Java的多个文件

使用XSLT将xml拆分为使用Java的多个文件,java,xml,xslt,transform,saxon,Java,Xml,Xslt,Transform,Saxon,我有一个XML文件,但需要根据Xpath变量上的匹配(包含)进行拆分 `<Apps> <App> <AppID>49O</AppID> <Type>MP Pay</Type> </App> <App> <AppID>715</AppID> <Type>DP Pay</Typ

我有一个XML文件,但需要根据Xpath变量上的匹配(包含)进行拆分

`<Apps>
    <App>
        <AppID>49O</AppID>
        <Type>MP Pay</Type>
    </App>
    <App>
        <AppID>715</AppID>
        <Type>DP Pay</Type>
    </App>
    <App>
        <AppID>716</AppID>
        <Type>MP Pay</Type>
    </App>
    <App>
        <AppID>725</AppID>
        <Type>CP Pay</Type>
    </App>
    <App>
        <AppID>728</AppID>
        <Type>MP Pay</Type>
    </App>
   <App>
        <AppID>728</AppID>
        <Type>CP Pay</Type>
    </App>
</Apps>`

以下是一种更基于规则的方法:

<xsl:template match="App[starts-with(Type, 'MP')]" mode="group">MP</xsl:template>

<xsl:template match="App[starts-with(Type, 'DP')]" mode="group">DP</xsl:template>

<xsl:template match="App" mode="group">Mismatched</xsl:template>

<xsl:function name="f:key" as="xs:string">
  <xsl:param name="e" as="element(App)"/>
  <xsl:apply-templates select="." mode="group"/>
</xsl:function>

<xsl:template match="Apps">
  <xsl:for-each-group select="App" group-by="f:key(.)">
      <xsl:result-document href="{current-grouping-key()}.xml">
         <Apps>
            <xsl:copy-of select="current-group()"/>
         </Apps>
      </xsl:result-document>
  </xsl:for-each-group>
</xsl:template>
MP
数据处理
错配

谢谢。工作完美!你也可以发布你的java代码吗?您是否使用Saxon、纯Java(与XSLT2.0一起使用)?谢谢,史蒂芬妮,我在用萨克森。在我的问题中添加了java代码
<?xml version="1.0" encoding="UTF-8" ?>
<xsl:stylesheet version="2.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
   <xsl:output indent="yes"/>

   <xsl:template match="Apps">
      <xsl:result-document href="MP.xml">
         <xsl:copy>
            <xsl:apply-templates select="App[contains(Type, 'MP')]"/>
         </xsl:copy>
      </xsl:result-document>
      <xsl:result-document href="DP.xml">
         <xsl:copy>
            <xsl:apply-templates select="App[contains(Type, 'DP')]"/>
         </xsl:copy>
      </xsl:result-document>
      <xsl:result-document href="Mismatched.xml">
         <xsl:copy>
            <xsl:apply-templates select="App[not(contains(Type, 'MP') or contains(Type, 'DP'))]"/>
         </xsl:copy>
      </xsl:result-document>
   </xsl:template>

   <xsl:template match="@* | node()">
      <xsl:copy>
         <xsl:apply-templates select="@* | node()"/>
      </xsl:copy>
   </xsl:template>
</xsl:stylesheet>
<xsl:template match="App[starts-with(Type, 'MP')]" mode="group">MP</xsl:template>

<xsl:template match="App[starts-with(Type, 'DP')]" mode="group">DP</xsl:template>

<xsl:template match="App" mode="group">Mismatched</xsl:template>

<xsl:function name="f:key" as="xs:string">
  <xsl:param name="e" as="element(App)"/>
  <xsl:apply-templates select="." mode="group"/>
</xsl:function>

<xsl:template match="Apps">
  <xsl:for-each-group select="App" group-by="f:key(.)">
      <xsl:result-document href="{current-grouping-key()}.xml">
         <Apps>
            <xsl:copy-of select="current-group()"/>
         </Apps>
      </xsl:result-document>
  </xsl:for-each-group>
</xsl:template>