【问题标题】:XSLT + Adding excel data type tags to cells based on the data type of header rowXSLT + 根据标题行的数据类型向单元格添加excel数据类型标签
【发布时间】:2012-02-16 00:35:19
【问题描述】:

我正在尝试使用 XSLT 将 ss:Type="Number" 分配给标题中包含数字的列中的所有数据单元格。到目前为止,我只能将它正确分配给标题行。

XSLT:

<!-- match the Columns element and create header row -->
<xsl:template match="Columns/*">
    <xsl:choose>
        <xsl:when test="@Description[boolean(number()) or . = 0]"> 
             <ss:Cell ss:StyleID="1">
               <ss:Data ss:Type="Number"><xsl:apply-templates select="@Description"/></ss:Data>
             </ss:Cell>
             <xsl:call-template name="numberFormat"/>
        </xsl:when>
        <xsl:otherwise>
             <ss:Cell ss:StyleID="1">
               <ss:Data ss:Type="String"><xsl:apply-templates select="@Description"/></ss:Data>
             </ss:Cell>
             <xsl:call-template name="stringFormat"/>
        </xsl:otherwise>
    </xsl:choose>
</xsl:template>

<xsl:template name="stringFormat" match="Row/*">
  <ss:Cell>
    <ss:Data ss:Type="String"><xsl:apply-templates/></ss:Data>
  </ss:Cell>
</xsl:template>

<xsl:template name="numberFormat" match="Row/*">
  <ss:Cell>
    <ss:Data ss:Type="Number"><xsl:apply-templates/></ss:Data>
  </ss:Cell>
</xsl:template>

结果:

        <ss:Row>
            <ss:Cell ss:StyleID="1">
<ss:Data ss:Type="Number">2012001 (Number Header)</ss:Data>
            </ss:Cell>
            <ss:Cell ss:StyleID="1">
<ss:Data ss:Type="String">String Header</ss:Data>
</ss:Cell>
        </ss:Row>
        <ss:Row>
            <ss:Cell>
<ss:Data ss:Type="Number">Row2Column1Data</ss:Data>
            </ss:Cell>
            <ss:Cell>
<ss:Data ss:Type="Number">Row2Column2Data</ss:Data>
            </ss:Cell>
        </ss:Row>
        <ss:Row>
            <ss:Cell>
<ss:Data ss:Type="Number">Row3Column1Data</ss:Data>
            </ss:Cell>
            <ss:Cell>
<ss:Data ss:Type="Number">Row3Column2Data</ss:Data>
            </ss:Cell>
        </ss:Row>

XML:

<Rowsets>
 <Rowset>
    <Columns>
        <Column Description="_2012001"/>
        <Column Description="StringHeader"/>
    </Columns>
    <Row>
        <_2012001>Row2Column1Data</_2012001>
        <StringHeader>Row2Column2Data</StringHeader>
    </Row>
    <Row>
        <_2012001>Row3Column1Data</_2012001>
        <StringHeader>Row3Column2Data</StringHeader>
    </Row>
 </Rowset>
</Rowsets>

目前,无论哪个模板是最后一个优先,所以在这种情况下,我的“numberFormat”模板是最后一个,ss:type 设置为 Number,即使我显式调用模板...

更新:期望的输出

//First header cell contains a numeric value -- the cell should have ss:Type="Number"
            <ss:Row>
                <ss:Cell ss:StyleID="1">
    <ss:Data ss:Type="Number">_2012001 (Number Header)</ss:Data>
                </ss:Cell>
//Second header cell contains a string value -- the cell should have ss:Type="String"
                <ss:Cell ss:StyleID="1">
    <ss:Data ss:Type="String">String Header</ss:Data>
                </ss:Cell>
            </ss:Row>

//ss:Type="Number" for the first column because the header row of that column contains a number
            <ss:Row>
                <ss:Cell>
    <ss:Data ss:Type="Number">Row2Column1Data</ss:Data>
                </ss:Cell>
//ss:Type="String" for the second column because the header row of that column is a String
                <ss:Cell>
    <ss:Data ss:Type="String">Row2Column2Data</ss:Data>
                </ss:Cell>
            </ss:Row>
            <ss:Row>
//ss:Type="Number" for the first column because the header row of that column contains a number
                <ss:Cell>
    <ss:Data ss:Type="Number">Row3Column1Data</ss:Data> 
                </ss:Cell>
//ss:Type="String" for the second column because the header row of that column is a String
                <ss:Cell>
    <ss:Data ss:Type="String">Row3Column2Data</ss:Data>
                </ss:Cell>
            </ss:Row>
    ...etc.

【问题讨论】:

  • 请编辑问题并指定所需的确切结果。然后我会提供一个解决方案。
  • 谢谢!我添加了我想要的输出

标签: xml xslt-1.0


【解决方案1】:

这种转变

<xsl:stylesheet version="1.0"
 xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
 xmlns:ss="some:ss" exclude-result-prefixes="ss">
 <xsl:output omit-xml-declaration="yes" indent="yes"/>
 <xsl:strip-space elements="*"/>

 <xsl:template match="/*">
  <t xmlns:ss="some:ss">
    <xsl:apply-templates/>
  </t>
 </xsl:template>

 <xsl:template match="Columns | Row">
  <ss:Row>
   <xsl:apply-templates/>
  </ss:Row>
 </xsl:template>

 <xsl:template priority="2" match=
  "Column[floor(substring(@Description, 2))
         =
          floor(substring(@Description, 2))
         ]
   ">
   <ss:Cell ss:StyleID="1">
     <ss:Data ss:Type="Number">
      <xsl:value-of select="@Description"/>
     </ss:Data>
   </ss:Cell>
  </xsl:template>

   <xsl:template match="Column">
   <ss:Cell ss:StyleID="1">
     <ss:Data ss:Type="String">
      <xsl:value-of select="@Description"/>
     </ss:Data>
   </ss:Cell>
 </xsl:template>

 <xsl:template priority="2" match=
  "Row/*[floor(substring(name(), 2))
        =
         floor(substring(name(), 2))
         ]
  ">
   <ss:Cell>
     <ss:Data ss:Type="Number">
      <xsl:value-of select="."/>
     </ss:Data>
   </ss:Cell>
 </xsl:template>

 <xsl:template match="Row/*">
   <ss:Cell>
     <ss:Data ss:Type="String">
      <xsl:value-of select="."/>
     </ss:Data>
   </ss:Cell>
 </xsl:template>
</xsl:stylesheet>

应用于提供的 XML 文档时

<Rowsets>
    <Rowset>
        <Columns>
            <Column Description="_2012001"/>
            <Column Description="StringHeader"/>
        </Columns>
        <Row>
            <_2012001>Row2Column1Data</_2012001>
            <StringHeader>Row2Column2Data</StringHeader>
        </Row>
        <Row>
            <_2012001>Row3Column1Data</_2012001>
            <StringHeader>Row3Column2Data</StringHeader>
        </Row>
    </Rowset>
</Rowsets>

产生想要的正确结果

<t>
   <ss:Row xmlns:ss="some:ss">
      <ss:Cell ss:StyleID="1">
         <ss:Data ss:Type="Number">_2012001</ss:Data>
      </ss:Cell>
      <ss:Cell ss:StyleID="1">
         <ss:Data ss:Type="String">StringHeader</ss:Data>
      </ss:Cell>
   </ss:Row>
   <ss:Row xmlns:ss="some:ss">
      <ss:Cell>
         <ss:Data ss:Type="Number">Row2Column1Data</ss:Data>
      </ss:Cell>
      <ss:Cell>
         <ss:Data ss:Type="String">Row2Column2Data</ss:Data>
      </ss:Cell>
   </ss:Row>
   <ss:Row xmlns:ss="some:ss">
      <ss:Cell>
         <ss:Data ss:Type="Number">Row3Column1Data</ss:Data>
      </ss:Cell>
      <ss:Cell>
         <ss:Data ss:Type="String">Row3Column2Data</ss:Data>
      </ss:Cell>
   </ss:Row>
</t>

解释

  1. 正确的模板和模式匹配。

  2. $n 可转换为整数时,使用floor($n) = floor($n)true() 这一事实。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2013-06-02
    • 2017-07-22
    • 2012-03-20
    • 1970-01-01
    • 1970-01-01
    • 2013-01-25
    • 2016-10-27
    • 1970-01-01
    相关资源
    最近更新 更多