使用 XSL 将文本值组合在一起
Combining text values together using 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 文件中,我在 'Meeting' 节点中,该节点具有以下内容:
<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>
输出:
W20160107
上面使用 xsl:variable
将表达式拆分成块,以便于阅读。从 XML 文档变量中选择目标元素的实际用法应该如下所示:
<xsl:value-of select="$MyXML/AssignmentHistory/*[name()=$name]"/>
我有一个 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 文件中,我在 'Meeting' 节点中,该节点具有以下内容:
<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>
输出:
W20160107
上面使用 xsl:variable
将表达式拆分成块,以便于阅读。从 XML 文档变量中选择目标元素的实际用法应该如下所示:
<xsl:value-of select="$MyXML/AssignmentHistory/*[name()=$name]"/>