gpt4 book ai didi

XSLT 拆分输出文件 - muenchian 分组

转载 作者:行者123 更新时间:2023-12-04 18:52:29 25 4
gpt4 key购买 nike

我有一个 XSLT 文件,以便转换大量数据。我想添加一个“拆分”功能,作为链接的 XSLT 或在当前 XSLT 中可以创建多个输出文件,以便将文件的大小限制在某个阈值以下。
让我们假设输入 XML 如下:

<People>
<Person>
<name>John</name>
<date>June12</date>
<workTime taskID="1">34</workTime>
<workTime taskID="2">12</workTime>
</Person>
<Person>
<name>John</name>
<date>June13</date>
<workTime taskID="1">21</workTime>
<workTime taskID="2">11</workTime>
</Person>
<Person>
<name>Jack</name>
<date>June19</date>
<workTime taskID="1">20</workTime>
<workTime taskID="2">30</workTime>
</Person>
</People>

XSLT 文件如下使用 muenchian 分组。
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:key name="PersonTasks" match="workTime" use="concat(@taskID, ../name)"/>
<xsl:template match="/">
<People>
<xsl:apply-templates select="//workTime[generate-id() = generate-id(key('PersonTasks',concat(@taskID, ../name))[1])]"/>
</People>
</xsl:template>

<xsl:template match="workTime">
<xsl:variable name="taskID">
<xsl:value-of select="@taskID"/>
</xsl:variable>
<xsl:variable name="name">
<xsl:value-of select="../name"/>
</xsl:variable>
<Person>
<name>
<xsl:value-of select="$name"/>
</name>
<taskID>
<xsl:value-of select="$taskID"/>
</taskID>
<xsl:for-each select="//workTime[../name = $name][@taskID = $taskID]">
<workTime>
<date>
<xsl:value-of select="../date"/>
</date>
<time>
<xsl:value-of select="."/>
</time>
</workTime>
</xsl:for-each>
</Person>
</xsl:template>
</xsl:stylesheet>

但是,作为输出,我想要如下几个文件而不是一个大文件。在这个例子中,我只为每个文件设置了一个名称……但这应该是一个参数。

第一人称输出文件:
<People>
<Person>
<name>John</name>
<taskID>1</taskID>
<workTime>
<date>June12</date>
<time>34</time>
</workTime>
<workTime>
<date>June13</date>
<time>21</time>
</workTime>
</Person>
<Person>
<name>John</name>
<taskID>2</taskID>
<workTime>
<date>June12</date>
<time>12</time>
</workTime>
<workTime>
<date>June13</date>
<time>11</time>
</workTime>
</Person>
</People>

第二人称的输出文件:
<People>
<Person>
<name>Jack</name>
<taskID>1</taskID>
<workTime>
<date>June19</date>
<time>20</time>
</workTime>
</Person>
<Person>
<name>Jack</name>
<taskID>2</taskID>
<workTime>
<date>June19</date>
<time>30</time>
</workTime>
</Person>
</People>

使用 XSLT 1.0 的首选和最优雅的方法是什么?有没有办法在 XSLT 中调用链接的 XSLT 以拆分输出文件?

干杯。

最佳答案

Is there a way to call a chained XSLT within the XSLT so as to split the output files?



几种方式 :
  • 您可以编写一个扩展函数来执行此操作 -- 检查您的 XSLT 处理器的文档。
  • 使用 <exsl:document> EXSLT 的扩展元素 ,如果您的 XSLT 处理器支持此功能
  • 使用 <saxon:output> 扩展元素 如果您有 Saxon 6.x
  • 在您的编程语言的循环中调用单独的转换 ,将要为其生成结果的人的姓名作为参数传递给它。

  • 以下是代码示例 对于上述 2. 和 3.:

    使用 <saxon:output> :
    <xsl:stylesheet version="1.0"
    xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
    xmlns:saxon="http://icl.com/saxon"
    extension-element-prefixes="saxon" >

    <xsl:template match="/">
    <xsl:for-each select="/*/*[not(. > 3)]">
    <saxon:output href="c:\xml\doc{.}">
    <xsl:copy-of select="."/>
    </saxon:output>
    </xsl:for-each>
    </xsl:template>
    </xsl:stylesheet>

    当此转换应用于以下 XML 文档时 :
    <nums>
    <num>01</num>
    <num>02</num>
    <num>03</num>
    <num>04</num>
    <num>05</num>
    <num>06</num>
    <num>07</num>
    <num>08</num>
    <num>09</num>
    <num>10</num>
    </nums>

    三个文件: c:\xml\doc1 , c:\xml\doc2c:\xml\doc3是用想要的内容创建的。

    使用 <exslt:document> 的相同示例:
    <xsl:stylesheet version="1.0"
    xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
    xmlns:ext="http://exslt.org/common"
    extension-element-prefixes="saxon" >

    <xsl:template match="/">
    <xsl:for-each select="/*/*[not(. > 3)]">
    <ext:document href="c:\xml\doc{.}">
    <xsl:copy-of select="."/>
    </ext:document>
    </xsl:for-each>
    </xsl:template>
    </xsl:stylesheet>

    关于XSLT 拆分输出文件 - muenchian 分组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4169961/

    25 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com