0

どうすればこれをソートできるか考えている人はいますか?xlst でタイムコード値の昇順で並べ替えたいのですが、通常の並べ替えではタイムコード値が正しく読み取れないと思います。

私の最終的な目標は、1) タイムコード値の昇順でノードをソートすることです。2) それぞれの色の最初の反復のタイムコード値を選択し、次に 2 番目、3 番目などを選択します。

さらに明確にする必要がある場合はお知らせください。

XML は次のとおりです。

<Metadata>
   <Locator>
   <Label>OUT</Label>
   <Color>Blue</Color>
   <Timecode>00;13;28;26</Timecode>
   <Username>bpayne</Username>
   <Track>V1</Track>
</Locator>
   <Locator>
   <Label>OUT</Label>
   <Color>Magenta</Color>
   <Timecode>00;15;29;26</Timecode>
   <Username>bpayne</Username>
   <Track>V1</Track>
   </Locator>
<Locator>
   <Label>IN</Label>
   <Color>Magenta</Color>
   <Timecode>00;23;48;19</Timecode>
   <Username>bpayne</Username>
   <Track>V1</Track>
</Locator>
<Locator>
   <Label>IN</Label>
   <Color>Magenta</Color>
   <Timecode>00;03;15;13</Timecode>
   <Username>bpayne</Username>
   <Track>V1</Track>
</Locator>
<Locator>
   <Label>OUT</Label>
   <Color>Magenta</Color>
   <Timecode>00;19;50;25</Timecode>
   <Username>bpayne</Username>
   <Track>V1</Track>
</Locator>
<Locator>
   <Label>IN</Label>
   <Color>Magenta</Color>
   <Timecode>00;25;58;05</Timecode>
   <Username>bpayne</Username>
   <Track>V1</Track>
</Locator>
<Locator>
   <Label>IN</Label>
   <Color>Magenta</Color>
   <Timecode>00;07;44;29</Timecode>
   <Username>bpayne</Username>
   <Track>V1</Track>
</Locator>
<Locator>
   <Label>OUT</Label>
   <Color>Magenta</Color>
   <Timecode>00;09;05;28</Timecode>
   <Username>bpayne</Username>
   <Track>V1</Track>
</Locator>
<Locator>
   <Label>IN</Label>
   <Color>Blue</Color>
   <Timecode>00;02;19;23</Timecode>
   <Username>bpayne</Username>
   <Track>V1</Track>
</Locator>
<Locator>
<Label>OUT</Label>
   <Color>Magenta</Color>
   <Timecode>00;13;16;11</Timecode>
   <Username>bpayne</Username>
   <Track>V1</Track>
</Locator>
<Locator>
    <Label>OUT</Label>
    <Color>Blue</Color>
    <Timecode>00;02;31;23</Timecode>
    <Username>bpayne</Username>
    <Track>V1</Track>
</Locator>

そして、これが私が使用しているXLSTの一部です。最初にノードをタイムコード値で並べ替えてから、次の XSLT で変換する必要があります。

    <?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
    xmlns:xs="http://www.w3.org/2001/XMLSchema"
    exclude-result-prefixes="xs"
    version="2.0">
    <xsl:template match="/">
        <TimeCodes>
            <G1_TC_1_IN>
                <xsl:choose>
                    <xsl:when test="Metadata/Locator[Color = 'Magenta'][1]">
                        <xsl:value-of select="concat(
                        substring-before(Metadata/Locator[Color = 'Magenta'][1]/Timecode, ';'), ':',
                        substring-before(substring-after(Metadata/Locator[Color = 'Magenta'][1]/Timecode, ';'), ';'), ':',
                        substring-after(substring-after(Metadata/Locator[Color = 'Magenta'][1]/Timecode, ';'), ';')
                        )"/>
                    </xsl:when>       
                    <xsl:otherwise>18:00:00;00</xsl:otherwise>
                </xsl:choose>
                <xsl:text>@29.97</xsl:text>
            </G1_TC_1_IN>
            <G1_TC_1_OUT>
                <xsl:choose>
                    <xsl:when test="Metadata/Locator[Color = 'Magenta'][2]">
                        <xsl:value-of select="concat(
                            substring-before(Metadata/Locator[Color = 'Magenta'][2]/Timecode, ';'), ':',
                            substring-before(substring-after(Metadata/Locator[Color = 'Magenta'][2]/Timecode, ';'), ';'), ':',
                            substring-after(substring-after(Metadata/Locator[Color = 'Magenta'][2]/Timecode, ';'), ';')
                            )"/>
                    </xsl:when>       
                    <xsl:otherwise>18:00:00;00</xsl:otherwise>
                </xsl:choose>
                <xsl:text>@29.97</xsl:text>
            </G1_TC_1_OUT>
........

<G2_TC_1_IN>
                <xsl:choose>
                    <xsl:when test="Metadata/Locator[Color = 'Blue'][1]">
                        <xsl:value-of select="concat(
                            substring-before(Metadata/Locator[Color = 'Blue'][1]/Timecode, ';'), ':',
                            substring-before(substring-after(Metadata/Locator[Color = 'Blue'][1]/Timecode, ';'), ';'), ':',
                            substring-after(substring-after(Metadata/Locator[Color = 'Blue'][1]/Timecode, ';'), ';')
                            )"/>
                    </xsl:when>       
                    <xsl:otherwise>18:00:00;00</xsl:otherwise>
                </xsl:choose>
                <xsl:text>@29.97</xsl:text>
            </G2_TC_1_IN>
4

1 に答える 1