我正在研究使用xslt、进行分组的Muenchian方法
数据与此相似
<Root>
<Entries>
<Entry Attribute="A"/>
<Entry Attribute="B"/>
<Entry Attribute="C"/>
</Entries>
</Root>
但除此之外,我还需要有一个预定义的排序顺序——对我的元素进行排序。因此,我考虑在xslt中使用排序顺序创建一个自定义xml部分,并将其插入到类似的变量中
<xsl:variable name="sortorder"select="document('')/*/my:data/my:ordering/my:value"/>
值是例如C、B、A,这是顺序并且还分组报头
然后我想到,我可以简单地循环遍历变量的值,而不是在Muenchian方法中使用key()函数。
像这个
<xsl:template match="Entries">
<xsl:for-each select="$sortorder/value">
<groupheader><xsl:value-of select="."/></groupheader>
然后应用模板
<xsl:apply-templates select="Entry[@sortattribute=current()"></xsl:apply-templates>
但我还没有把它发挥作用。关于如何做到这一点,有什么建议吗?我走对了吗?我怀疑我在<条目>s,但我不知道如何更正。
下面是一个可以作为指南的通用示例:
XML
<input>
<item category="Winter">Alpha</item>
<item category="Autumn">Bravo</item>
<item category="Spring">Charlie</item>
<item category="Summer">Delta</item>
<item category="Spring">Echo</item>
<item category="Autumn">Foxtrot</item>
<item category="Spring">Golf</item>
<item category="Summer">Hotel</item>
<item category="Winter">India</item>
<item category="Autumn">Juliet</item>
<item category="Summer">Kilo</item>
<item category="Winter">Lima</item>
<item category="Summer">Mike</item>
<item category="Spring">November</item>
<item category="Spring">Oscar</item>
<item category="Autumn">Papa</item>
<item category="Winter">Quebec</item>
<item category="Summer">Romeo</item>
<item category="Spring">Sierra</item>
<item category="Summer">Tango</item>
<item category="Spring">Uniform</item>
<item category="Autumn">Victor</item>
<item category="Summer">Whiskey</item>
<item category="Winter">Xray</item>
<item category="Summer">Yankee</item>
<item category="Autumn">Zulu</item>
</input>
XSLT 1.0
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:my="http://www.example.com/my"
exclude-result-prefixes="my">
<xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes"/>
<my:categories>
<category>Spring</category>
<category>Summer</category>
<category>Autumn</category>
<category>Winter</category>
</my:categories>
<xsl:variable name="root" select="/"/>
<xsl:template match="/">
<output>
<xsl:for-each select="document('')/xsl:stylesheet/my:categories/category">
<group category="{.}">
<xsl:apply-templates select="$root/input/item[@category=current()]"/>
</group>
</xsl:for-each>
</output>
</xsl:template>
<xsl:template match="item">
<xsl:copy-of select="."/>
</xsl:template>
</xsl:stylesheet>
结果
<?xml version="1.0" encoding="UTF-8"?>
<output>
<group category="Spring">
<item category="Spring">Charlie</item>
<item category="Spring">Echo</item>
<item category="Spring">Golf</item>
<item category="Spring">November</item>
<item category="Spring">Oscar</item>
<item category="Spring">Sierra</item>
<item category="Spring">Uniform</item>
</group>
<group category="Summer">
<item category="Summer">Delta</item>
<item category="Summer">Hotel</item>
<item category="Summer">Kilo</item>
<item category="Summer">Mike</item>
<item category="Summer">Romeo</item>
<item category="Summer">Tango</item>
<item category="Summer">Whiskey</item>
<item category="Summer">Yankee</item>
</group>
<group category="Autumn">
<item category="Autumn">Bravo</item>
<item category="Autumn">Foxtrot</item>
<item category="Autumn">Juliet</item>
<item category="Autumn">Papa</item>
<item category="Autumn">Victor</item>
<item category="Autumn">Zulu</item>
</group>
<group category="Winter">
<item category="Winter">Alpha</item>
<item category="Winter">India</item>
<item category="Winter">Lima</item>
<item category="Winter">Quebec</item>
<item category="Winter">Xray</item>
</group>
</output>
请注意使用$root
变量将上下文返回到输入XML文档。