2011-05-31 53 views
5

内我解析.xml文件等:在的.xsl,取像“130-210”的范围内的值,并确定是否“86”或“458”是数值范围

<xml> 
    <normalRange>100-200</normalRange> 
    <value>83</value> 
</xml> 

在.xls样式表中,我需要显示一个值,该值指示该值是否在normalRange内,其下方或上方。

从CCR(保健HL7消息传递中的护理记录的连续性)xml文档显示人类可读结果时,这是一个非常常见的问题。

+0

你是在电子表格单元格内还是在VBA内完成这项工作?在任何一种情况下,只需检查值 MaxValue。 – 2011-05-31 03:18:41

+0

不,这是原始的.xml和.xls文件。 (没有电子表格或VBA。) – MikeN 2011-05-31 03:26:29

回答

7
<?xml version="1.0" encoding="UTF-8"?> 
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"> 

<xsl:template match="/"> 
    <xsl:variable name="value" select="/xml/value"/> 
    <xsl:variable name="low" select="substring-before(/xml/normalRange, '-')"/> 
    <xsl:variable name="high" select="substring-after(/xml/normalRange, '-')"/> 

    <xsl:choose> 
     <xsl:when test="$value &lt; $low"> 
      <output>below</output> 
     </xsl:when> 
     <xsl:when test="$value &gt; $high"> 
      <output>above</output> 
     </xsl:when> 
     <xsl:otherwise> 
      <output>within</output> 
     </xsl:otherwise> 
    </xsl:choose> 
</xsl:template> 

</xsl:stylesheet> 

请注意,元素名称“xml”由XML 1.0 standard保留,因此避免它可能是个好主意。

+1

感谢您的帮助!我欠你5美元。让我知道你是否在找工作。 – MikeN 2011-05-31 03:40:19