我有一个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]"/>