使用 XSL 将文本值组合在一起



我有一个XML文件。片段:

<?xml version="1.0" encoding="UTF-8"?>
<AssignmentHistory>
<W20160104>
    <StudentItems>
        <Item>
            <Name Counsel="13">Name 1</Name>
            <Type>Type 1</Type>
        </Item>
    </StudentItems>
</W20160104>

我想创建一个主要与另一个 XML 文件一起使用的 XSL 脚本。但是,它也使用此方法引用上述外部 XML 文件:

<xsl:variable name="MyXML" select "document('history.xml')"/>

在主XML文件中,我位于具有以下内容的"会议"节点中:

<MeetingDate Day="7" DayShort="Thu" DayFull="Thursday" Month="1" MonthShort="Jan" MonthFull="January" Year="2016"/>

我想做的是将@Day、@Month和@Year属性结合起来,这样我最终得到"WYYYYMMDD",这样我就可以有希望找到:

/AssignmentHistory/WYYYYMMDD

这样我就可以在最终输出中包含 MyXML 中该节点的一些值。

您能否告诉我如何获取属性并将它们转换为"WYYYYMMDD"?

谢谢。

多亏了你的评论,我取得了一些进展。我现在可以格式化 WYYYYMMDD 文本值。但我正在努力迭代外部文档:

            <xsl:variable name="AssignHistory" select="document('AssignHistory.xml')"/>
            <xsl:variable name="y" select="MeetingDate/@Year"/>
            <xsl:variable name="m" select="format-number(MeetingDate/@Month, '00')"/>
            <xsl:variable name="d" select="format-number(MeetingDate/@Day, '00')"/>
            <xsl:variable name="week" select="concat('W',$y,$m,$d)"/>
            <xsl:value-of select="$week"/><br />
            <xsl:for-each select="$AssignHistory/AssignmentHistory/*[name()=$week]/StudentItems/Item">
              Student (or assistant): <xsl:value-of select="Name"/><br />
            </xsl:for-each>

什么都没有显示。

这是以所需格式生成字符串的一种可能的方法"WYYYMMDD"

<xsl:template match="MeetingDate">
    <xsl:variable name="y" select="@Year"/>
    <xsl:variable name="m" select="format-number(@Month, '00')"/>
    <xsl:variable name="d" select="format-number(@Day, '00')"/>
    <xsl:variable name="name" select="concat('W',$y,$m,$d)"/>
    <xsl:value-of select="$name"/>
</xsl:template>

xsltranfsorm.net demo

输出:

W20160107

上面使用了xsl:variable将表达式拆分为块,以使其更易于阅读。从XML文档变量中选择目标元素的实际用法应如下所示:

<xsl:value-of select="$MyXML/AssignmentHistory/*[name()=$name]"/>

相关内容

  • 没有找到相关文章

最新更新