xsl:sort 在 JDK 1.6 中不起作用 / 默认 xalan 2.7.0



由于某些原因,非常简单的xsl:sort对我不起作用。(如果我犯了愚蠢的错误,我道歉)

我在JDK 1.6中遇到了这个奇怪的巫毒魔法行为(检查我的xalan版本是2.7.0)。下面的xml、xslt、xsl:sort在从java运行时不起作用。

在我的代码中,xslt被编译和缓存,每次我都得到一个模板来进行转换。

我的xml:

<?xml version="1.0" encoding="UTF-8"?>
<stats>
    <matches>
        <match>
            <goal>10</goal>
            <goal>2</goal>
            <goal>30</goal>
            <goal>344</goal>
            <goal>59</goal>
            <goal>6</goal>
            <goal>27</goal>
            <goal>18</goal>
            <goal>999</goal>
        </match>
    </matches>
</stats>

和xslt:

<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet version="1.0"
    xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
    <xsl:output method="xml" indent="yes" />
    <xsl:template name="min">
        <xsl:param name="nodes" />
        <xsl:for-each select="$nodes">
            <xsl:sort data-type="number" />
            <xsl:if test="position() = 1">
                <xsl:element name="result">
                    <xsl:value-of select="number(.)" />
                </xsl:element>
            </xsl:if>
        </xsl:for-each>
    </xsl:template>
    <xsl:template name="max">
        <xsl:param name="nodes" />
        <xsl:for-each select="$nodes">
            <xsl:sort data-type="number" order="descending" />
            <xsl:if test="position() = 1">
                <xsl:element name="result">
                    <xsl:value-of select="number(.)" />
                </xsl:element>
            </xsl:if>
        </xsl:for-each>
    </xsl:template>
    <xsl:template match="/">
        <xsl:variable name="tails"
            select="/stats/matches/match/goal" />
        <xsl:call-template name="min">
            <xsl:with-param name="nodes" select="$tails" />
        </xsl:call-template>
        <xsl:call-template name="max">
            <xsl:with-param name="nodes" select="$tails" />
        </xsl:call-template>
    </xsl:template>
<xsl:template match="text()" />
</xsl:stylesheet>

在我的java程序中没有得到预期的输出:

<?xml version="1.0" encoding="UTF-8"?>
<result>2</result>
<result>999</result> 

——为我的测试Java程序添加了代码----

import java.io.File;
import java.io.StringWriter;
import javax.xml.transform.Templates;
import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.stream.StreamResult;
import javax.xml.transform.stream.StreamSource;
public class XsltTest {
    /**
     * @param args
     */
    public static void main(String[] args) {
        System.out.print("XsltTest");
        TransformerFactory tf = TransformerFactory.newInstance();
        try {
            Templates templates = tf.newTemplates(new StreamSource(new File(
                    "src/main/resources/test.xsl")));
            Transformer tr = templates.newTransformer();
            StringWriter sw = new StringWriter();
            tr.transform(new StreamSource(new File("src/main/resources/test.xml")), new StreamResult(sw));
            System.out.println();
            System.out.println(sw.toString());
        } catch (Exception e) {
            System.err.print(e);
        }
    }
}

我可以确认这与Saxon 9.5的预期一致。所以我不认为你的代码有什么问题。因此,要么您正在使用的Xalan版本有错误,要么您调用它的方式不正确。(如果你告诉我们它是如何失败的,而不是仅仅说"它不起作用",那么我们就有线索了。)

除了在JDK中嵌入Xalan的便利性之外,现在没有理由再使用Xalan了。它已经好几年没有更新了,也没有人修复bug。它只提供XSLT 1.0,这严重限制了您可以做的事情。切换到Saxon

最新更新