10

XLSTを使用することはめったになく、親ノードの子ノードをカウントしようとすると混乱する結果になります。

編集:

XMLは次のように構成されています。

<?xml version="1.0"?>
<Response>
  <result>
    <name>Someone</name>
    **<rating>4.5</rating>**
    <review>
      <text>Some review.</text>
    </review>
    <review>
      <text>Another review.</text>
    </review>
  </result>
  <result>
    <name>Another one</name>
    **<rating>2</rating>**
    <review>
      <text>Blah, grieve, blah.</text>
    </review>
    <review>
      <text>Blah, grrrrr, blah.</text>
    </review>
    <review>
      <text>Blah, good grrrrr, blah.</text>
    </review>
  </result>
  ...
  ...
</Response>

テンプレート(簡略化)は次のとおりです。

**<body>
      <xsl:apply-templates/>
</body>**

<xsl:template match="Response/result">
  <div class="item">
    <div class="name">
      <xsl:value-of select="name"/>
    </div>
    <xsl:if test="rating">
        <span class="review-count">
          **(<xsl:value-of select="count(review)"/>)**
        </span>
    </xsl:if>
  </div>
</xsl:template>

このアプローチでは、正しい子ノード数を取得できません。に加えて、いくつかのxPathバリエーションcount(review)を試しました。count(descendant::review)単純なものが欠けていることはわかっていますが、何ですか?

4

1 に答える 1

14
<xsl:if test="rating">
    <span class="review-count">
      **(<xsl:value-of select="count(review)"/>)**
    </span>
</xsl:if>

rating提供されたXMLドキュメントには要素がないため、これによって1文字も生成されることはありません。上記の条件付き命令を削除すると、結果には必要なカウント値が含まれます。

実際ratingに少なくともいくつかのreview要素の子がある場合(ただし、これを表示できなかった場合)、デフォルトの名前空間など、XMLドキュメントの他の重要な部分も表示しなかった可能性があります。

更新

ratingOPは、要素を含むより正確なXMLドキュメントを提供しています。

問題を再現できません

このXSLT変換

<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
 <xsl:output omit-xml-declaration="yes" indent="yes"/>

    <xsl:template match="Response/result">
      <div class="item">
        <div class="name">
          <xsl:value-of select="name"/>
        </div>
        <xsl:if test="rating">
            <span class="review-count">
              **(<xsl:value-of select="count(review)"/>)**
            </span>
        </xsl:if>
      </div>
    </xsl:template>
</xsl:stylesheet>

提供されたXMLドキュメントに適用した場合

<Response>
  <result>
    <name>Someone</name>
      <rating>4.5</rating>
    <review>
      <text>Some review.</text>
    </review>
    <review>
      <text>Another review.</text>
    </review>
  </result>
  <result>
    <name>Another one</name>
      <rating>2</rating>
    <review>
      <text>Blah, grieve, blah.</text>
    </review>
    <review>
      <text>Blah, grrrrr, blah.</text>
    </review>
    <review>
      <text>Blah, good grrrrr, blah.</text>
    </review>
  </result>
  ...
  ...
</Response>

必要な正しい結果を生成します。

  <div class="item">
   <div class="name">Someone</div>
   <span class="review-count">
              **(2)**
            </span>
</div>

<div class="item">
   <div class="name">Another one</div>
   <span class="review-count">
              **(3)**
            </span>
</div>
  ...
  ...
于 2013-01-04T03:16:49.423 に答える