由于某些原因,非常简单的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