0

ドキュメント内の各テーブルについて、「単純」または「複雑」と定義したいと思います。各行に最大で 2 つの列が含まれる場合は「単純」である必要があり、それ以外の場合は「複雑」である必要があります。

xsltでこれを行うにはどうすればよいですか?

4

2 に答える 2

1

お時間をいただき申し訳ございませんでした。私は解決策を思いつきました。誰かが必要な場合は、ここに答えがあります。

<xsl:template match="TABLE">
<xsl:variable name="tableClass">
    <xsl:choose>
        <xsl:when test="count(TBODY/TR[count(child::*) = 2]) = count(TBODY/TR)">
            simple
        </xsl:when>
        <xsl:otherwise>
            complicated
        </xsl:otherwise>
    </xsl:choose>
</xsl:variable>
<table class="{$tableClass}">
    <xsl:apply-templates select="CAPTION"/>
    <xsl:apply-templates select="TBODY"/>
    and so on.......
</table>

于 2010-03-16T14:26:59.847 に答える
0

2 つの XML ドキュメントが与えられた場合、A:

<base>
  <row>
    <col1 value='x'/>
    <col2/>
  </row>
  <row>
    <col1 value='y'/>
    <col2/>
  </row>
  <row>
    <col1 value='z'/>
    <col2/>
  </row>
</base>

と B:

<base>
  <row>
    <col1/>
    <col2/>
    <col3/>
  </row>

  <row>
    <col1/>
    <col2/>
  </row>
</base>

この xsl は、各トップレベルの行要素の下にある子要素の数に基づいて、「単純」か「複雑」かを示します。

<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
  <xsl:output method="text" encoding = "iso-8859-1"/>

  <!-- is the xml simple? -->
  <!-- simple, in this case, means each row has 2 or fewer columns -->


  <xsl:variable name="maxColCount">
     <xsl:for-each select="//base/row">
       <xsl:sort data-type="number" order="descending"/>
       <xsl:if test="position()=1"><xsl:value-of select="count(./*)"/></xsl:if>
     </xsl:for-each>
   </xsl:variable>


  <xsl:template match="/">
    <xsl:choose>
      <xsl:when test="$maxColCount > 2">complex</xsl:when>
      <xsl:otherwise>simple</xsl:otherwise>
    </xsl:choose>
  </xsl:template>

</xsl:stylesheet>

結果は、A は単純、B は複雑です。

于 2010-03-16T14:44:36.973 に答える