XSLT pour sommer une colonne dans une WebPart Affichage de données
-
16-10-2019 - |
Question
J'ai cette (pour tenter de résoudre la tâche):
<xsl:stylesheet xmlns:x="http://www.w3.org/2001/XMLSchema" xmlns:d="http://schemas.microsoft.com/sharepoint/dsp" version="1.0" exclude-result-prefixes="xsl msxsl ddwrt" xmlns:ddwrt="http://schemas.microsoft.com/WebParts/v2/DataView/runtime" xmlns:asp="http://schemas.microsoft.com/ASPNET/20" xmlns:__designer="http://schemas.microsoft.com/WebParts/v2/DataView/designer" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:msxsl="urn:schemas-microsoft-com:xslt" xmlns:SharePoint="Microsoft.SharePoint.WebControls" xmlns:ddwrt2="urn:frontpage:internal">
<xsl:output method="html" indent="no"/>
<xsl:decimal-format NaN=""/>
<xsl:template match="/">
<xsl:variable name="Rows" select="/dsQueryResponse/Rows/Row"/>
<xsl:value-of select="sum($Rows/@Distance[.!=''])" />
</xsl:template>
</xsl:stylesheet>
Le résultat est le suivant: « nan », donc je figure que mon XSLT est erroné.
La question est: Comment puis-je écrire le XSLT pour calculer et afficher la somme de toutes les valeurs dans la colonne « Distance » dans une WebPart Affichage de données? La colonne peut avoir des valeurs vides (ne pas les valeurs vides maintenant par le chemin) qui devrait INCONTOURNABLE calculer la somme.
Mise à jour 1:
<xsl:decimal-format grouping-separator="." decimal-separator="," NaN="" name="european"/>
<xsl:template match="/">
Test:
<xsl:copy-of
select="format-number(sum(for ($i in /dsQueryResponse/Rows/Row/@Distance) { return number(replace($i, ',','.')})), '#,##', 'european')" />
Essayé, mais il échoue (processeur paramètre Echec stylesheet. Prévu jeton ')' trouve 'NOM'.
Mise à jour 2:
<xsl:template match="/">
xsum //Distance = <xsl:call-template name="xsum"><xsl:with-param name="currnode" select="//row/@Distance[1]"/></xsl:call-template>
<xsl:template name="xsum">
<xsl:param name="currnode"/>
<xsl:param name="res" select="0"/>
<xsl:choose>
<xsl:when test="$currnode">
<xsl:call-template name="xsum">
<xsl:with-param name="currnode" select="$currnode/following-sibling::tal[1]"/>
<xsl:with-param name="res" select="$res + translate($currnode,',','.')"/>
</xsl:call-template>
</xsl:when>
<xsl:otherwise>
<xsl:value-of select="translate($res,'.',',')"/>
</xsl:otherwise>
</xsl:choose>
</xsl:template>
J'ai le XSLT ci-dessus et il fournit la production, mais avec les valeurs suivantes dans la colonne Distance:
2 3,5 -1,3 0
je reçois un autre résultat de NaN mais pas la somme, seule la première valeur pour autant que je peux voir. Le résultat est le suivant:. XSUM // Distance = 2
Mise à jour 3:
Cela fonctionne. A eu quelques problèmes avec la sélection du noeud de départ, mais qui devrait être fixé dès maintenant.
<xsl:decimal-format name="da-DK" decimal-separator="," grouping-separator="." minus-sign="-" NaN="Ikke tal"/>
<xsl:output method="html"/>
<xsl:template match="/">
<xsl:text>Distance tilbagelagt = </xsl:text>
<xsl:call-template name="xsum">
<xsl:with-param name="currnode" select="//Row[1]"/>
<xsl:with-param name="attr-type" select="'Distance'"/>
<xsl:with-param name="res" select="0"/>
</xsl:call-template> km
<xsl:template name="xsum">
<xsl:param name="currnode"/>
<xsl:param name="attr-type"/>
<xsl:param name="res" select="0"/>
<xsl:choose>
<xsl:when test="$currnode/following-sibling::Row">
<xsl:call-template name="xsum">
<xsl:with-param name="currnode" select="$currnode/following-sibling::Row[1]"/>
<xsl:with-param name="attr-type" select="$attr-type"/>
<xsl:with-param name="res" select="$res + number(translate($currnode/@*[name() = $attr-type],',','.'))"/>
</xsl:call-template>
</xsl:when>
<xsl:otherwise>
<xsl:value-of select="format-number($res + number(translate($currnode/@*[name() = $attr-type],',','.')), '#,##','da-DK')"/>
</xsl:otherwise>
</xsl:choose>
</xsl:template>
La solution
Consultez cette Nombre avec décimales, comme le montre NAN dans DataFormWebPart
Autres conseils
Cela devrait fonctionner:
<xsl:value-of select="sum($Rows[string-length(@Distance) > 0]/@Distance)" />
M.