我有一个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属性,以便最终得到&#34; WYYYYMMDD&#34;这样我就可以找到:
/AssignmentHistory/WYYYYMMDD
这样我就可以在MyXML的最终输出中包含该节点的一些值。
请告诉我如何获取属性并将其转换为&#34; WYYYYMMDD&#34;?
非常感谢。
感谢您的评论,我取得了一些进展。我现在可以格式化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>
什么都没有显示。
答案 0 :(得分:1)
这是以所需格式生成字符串的一种可能方式"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]"/>