gpt4 book ai didi

xml - XSLT 按子元素排序和分组

转载 作者:数据小太阳 更新时间:2023-10-29 02:31:42 26 4
gpt4 key购买 nike

`我有一个 XML 文件,其中包含很多“入口”节点。在每个“条目”节点中,通常有一个“年份”和“标题”子节点。

我正在尝试生成如下所示的 HTML 输出:

2012
Title
Title

2011
Title

2010
Title
Title

只要具有唯一年份的条目存在,这种模式就应该继续。我无法让它只打印一次年份。我可以让它每年打印一次,但它只会打印一个(假设是第一个)条目的标题。我可以让它打印每个条目的年份,但它会显示每个条目的年份。我使用了变量、生成 ID 和 key 的组合,但遇到了描述的问题(我可能做错了每一个)。

  • 对年数、参赛作品数量或每年/组的参赛作品数量没有限制。
  • 每年只应显示一次。

就 HTML 而言,我希望每个子组(共享一年)都在其自己的有序列表中,但如果这不可能,我也不会感到惊讶!

.

我正在使用的 XML 文件的一般模式是这样的:

root
Entry
Title
Year

<root>
<Entry>
<Title>Num 1</Title>
<Year>1991</Year>
</Entry>
<Entry>
<Title>Num 2</Title>
<Year>2011</Year>
</Entry>
<Entry>
<Title>Num 3</Title>
<Year>2012</Year>
</Entry>
<Entry>
<Title>Num 4</Title>
<Year>2012</Year>
</Entry>
</root>

XSL 版本 1.0 或 2.0 都可以。

这是 Entry 的模板匹配(它只获取元素并将所有内容放在单行列表项中)。

  •     <xsl:if test="Download">
    <xsl:text disable-output-escaping="yes">&lt;a href="http://thisisnot.real/publications/</xsl:text>
    <xsl:value-of select="Download"/>
    <xsl:text disable-output-escaping="yes">"&gt;</xsl:text>
    </xsl:if>
    <xsl:value-of select="Title"/>
    <xsl:if test="Download">
    <xsl:text disable-output-escaping="yes">&lt;/a&gt;</xsl:text>
    </xsl:if>
    <xsl:text>, </xsl:text>

    <!-- Add the handling for (possibly multiple) Authors -->
    <xsl:for-each select="Author">
    <xsl:value-of select="."/>,
    </xsl:for-each>




    <xsl:text>In </xsl:text>
    <EM>
    <xsl:value-of select="Booktitle"/>
    </EM>
    <xsl:text>, </xsl:text>

    <!-- Add the handling for Page -->
    <xsl:if test="Page">
    page <xsl:value-of select="Page"/>,
    </xsl:if>

    <!-- Add the handling for Address -->
    <xsl:if test="Address">
    <xsl:value-of select="Address"/>,
    </xsl:if>

    <!-- Add the handling for Year-Convert numeric Month to letters: eg, from 1 to January -->
    <xsl:for-each select="Month">
    <xsl:choose>
    <xsl:when test=".=1">January <xsl:value-of select="../Year"/></xsl:when>
    <xsl:when test=".=2">February <xsl:value-of select="../Year"/></xsl:when>
    <xsl:when test=".=3">March <xsl:value-of select="../Year"/></xsl:when>
    <xsl:when test=".=4">April <xsl:value-of select="../Year"/></xsl:when>
    <xsl:when test=".=5">&gt;May <xsl:value-of select="../Year"/></xsl:when>
    <xsl:when test=".=6">June <xsl:value-of select="../Year"/></xsl:when>
    <xsl:when test=".=7">July <xsl:value-of select="../Year"/></xsl:when>
    <xsl:when test=".=8">August <xsl:value-of select="../Year"/></xsl:when>
    <xsl:when test=".=9">September <xsl:value-of select="../Year"/></xsl:when>
    <xsl:when test=".=10">October <xsl:value-of select="../Year"/></xsl:when>
    <xsl:when test=".=11">November <xsl:value-of select="../Year"/></xsl:when>
    <xsl:when test=".=12">December <xsl:value-of select="../Year"/></xsl:when>
    </xsl:choose>
    </xsl:for-each>

    <!-- Add the handling for Note -->
    <xsl:if test="Note">
    <em>(<xsl:value-of select="Note"/>)</em>
    </xsl:if>

    <!-- Add the handling for AcceptRate in the grey color: #333333 -->
    <xsl:if test="AcceptRate">
    <font color="#333333"><small> Acceptance Rate: <xsl:value-of select="AcceptRate"/></small></font>
    </xsl:if>

    <!-- Add the handling for Award in the red color: #ff0000 -->
    <xsl:if test="Award">
    <font color="#ff0000"><strong> (<xsl:value-of select="Award"/>)</strong></font>
    </xsl:if>

      </LI>

  • 最佳答案

    这是一个 2.0 选项...

    XML 输入

    <root>
    <Entry>
    <Title>Title B</Title>
    <Year>2010</Year>
    </Entry>
    <Entry>
    <Title>Title A</Title>
    <Year>2010</Year>
    </Entry>
    <Entry>
    <Title>Title B</Title>
    <Year>2012</Year>
    </Entry>
    <Entry>
    <Title>Title A</Title>
    <Year>2011</Year>
    </Entry>
    <Entry>
    <Title>Title A</Title>
    <Year>2012</Year>
    </Entry>
    </root>

    XSLT 2.0

    <xsl:stylesheet version="2.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
    <xsl:output indent="yes"/>
    <xsl:strip-space elements="*"/>

    <xsl:template match="root">
    <html>
    <xsl:for-each-group select="Entry" group-by="Year">
    <xsl:sort select="Year" data-type="number" order="descending"/>
    <p><xsl:value-of select="Year"/></p>
    <ol>
    <xsl:apply-templates select="current-group()/Title">
    <xsl:sort select="." data-type="text" order="ascending"/>
    </xsl:apply-templates>
    </ol>
    </xsl:for-each-group>
    </html>
    </xsl:template>

    <xsl:template match="Title">
    <li><xsl:value-of select="."/></li>
    </xsl:template>

    </xsl:stylesheet>

    HTML 输出(代码)

    <html>
    <p>2012</p>
    <ol>
    <li>Title A</li>
    <li>Title B</li>
    </ol>
    <p>2011</p>
    <ol>
    <li>Title A</li>
    </ol>
    <p>2010</p>
    <ol>
    <li>Title A</li>
    <li>Title B</li>
    </ol>
    </html>

    HTML 输出(显示)

    2012

    1. 标题A
    2. 标题B

    2011

    1. 标题A

    2010

    1. 标题A
    2. 标题B

    关于xml - XSLT 按子元素排序和分组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9703927/

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