Использование fn: sum в XSLT с набором узлов, содержащих нулевые значения - PullRequest
7 голосов
/ 17 февраля 2010

Я пытаюсь суммировать набор значений в XML, используя функции XSLT и XPath fn: sum. Это работает нормально, пока значения не равны NULL, однако это не так. Чтобы проиллюстрировать мою проблему, я сделал пример:

<?xml version="1.0"?>

<xsl:stylesheet version="2.0"
                xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
                xmlns:fn="http://www.w3.org/2005/xpath-functions">

  <xsl:template match="/root">
    <root>
      <!-- Works fine for non-null values -->
      <sum><xsl:value-of select="fn:sum(values/value)" /></sum>
    </root>
  </xsl:template>
</xsl:stylesheet>

и XML:

<?xml version="1.0"?>
<root>
  <values>
    <value>1</value>
    <value>2</value>
    <value>3</value>
    <value>4</value>
    <!-- Nullvalue -->
    <value />
  </values>
</root>

Пример работает нормально, пока нет нулевых значений. Я пробовал различные варианты выбора, такие как <xsl:value-of select="fn:sum(values[value != '']/value)" /> (как вы могли заметить, небольшая часть экспорта XSLT;)) Как я могу отфильтровать нулевые значения?

Ответы [ 3 ]

9 голосов
/ 17 февраля 2010

Явно проверьте, что узлы имеют содержимое:

<sum><xsl:value-of select="fn:sum(values/value[text()])" /></sum>

Я думаю, что вы упомянули:

<xsl:value-of select="fn:sum(values[value != '']/value)" /> 

не работает, потому что узел пуст - он вообще не содержит текстового узла, тогда как value != '' проверяет наличие пустой строки, то есть текстового узла, имеющего данные длины 0.

6 голосов
/ 17 февраля 2010

Суммируем только те элементы, которые содержат числа:

<sum>
    <xsl:value-of select="fn:sum(values/value[number(.)=number(.)])" />
</sum>

Результат number() будет NaN для пустых элементов или элементов, строковое значение которых не является числом.

Ссылка MSDN - http://msdn.microsoft.com/en-us/library/ms256211.aspx

0 голосов
/ 18 февраля 2013

http://www.stylusstudio.com/xsllist/199909/post60110.html

XML:

<?xml version="1.0"?>
<doc>
    <num>1</num>
    <num>7</num>
    <notnum>hello world</notnum>
    <num>4</num>
</doc>

XSLT:

<?xml version="1.0"?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/XSL/Transform/1.0">
    <xsl:template match="/">
        <xsl:value-of select="sum(/doc/num)"/>
    </xsl:template>
</xsl:stylesheet>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...