IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

QlikView Discussion :

Somme des lignes dans tableau CROISE DYNAMIQUE


Sujet :

QlikView

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Juin 2010
    Messages
    31
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2010
    Messages : 31
    Points : 20
    Points
    20
    Par défaut Somme des lignes dans tableau CROISE DYNAMIQUE
    Bonjour,

    voilà mon souci :
    j'ai un tableau croisé dynamique dans lequel je souhaite afficher des totaux par dimension MAIS ceux-si doivent correspondre à la somme des lignes.

    C'est réalisable pour des tableaux simples via Propriétés du graphique > Expressions > Totaux > somme des lignes. En revanche pour les tableaux croisés je ne vois pas comment faire..

    Dans le cadre des tableaux croisés dynamiques je suis passée par Propriétés du graphique > Présentation > Sous totaux mais les résultats sont faussés.

    Je vous mets en PJ les explications dans un fichier Excel. Il y a des commentaires sur certaines cellules.
    J'espère que vous allez pouvoir m'éclairer ça m'aiderait beaucoup!!

    Merci d'avance!
    Fichiers attachés Fichiers attachés

  2. #2
    Membre expérimenté
    Homme Profil pro
    Inscrit en
    Septembre 2008
    Messages
    940
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 940
    Points : 1 409
    Points
    1 409
    Par défaut
    Essayez de remplacer votre formule
    if(sum(actif_net_global)=0, last_actif_net_global, sum(actif_net_global))

    par :
    sum(if(actif_net_global=0,last_actif_net_global,actif_net_global))

    Et dites-nous si ça marche !

  3. #3
    Membre à l'essai
    Profil pro
    Inscrit en
    Juin 2010
    Messages
    31
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2010
    Messages : 31
    Points : 20
    Points
    20
    Par défaut
    Citation Envoyé par FORMULARY Voir le message
    Essayez de remplacer votre formule
    if(sum(actif_net_global)=0, last_actif_net_global, sum(actif_net_global))

    par :
    sum(if(actif_net_global=0,last_actif_net_global,actif_net_global))

    Et dites-nous si ça marche !
    J'ai essayé avec votre formule mais malheureusement ça ne marche pas..

    j'ai les même résultats qu'avec la formule initiale SAUF pour les lignes dont l'actif_net_global est égal à zéro : il y a désormais "zero" à la place de "la valeur rouge"!

    Merci qd même de vous être penché sur le sujet

  4. #4
    Membre expérimenté
    Homme Profil pro
    Inscrit en
    Septembre 2008
    Messages
    940
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 940
    Points : 1 409
    Points
    1 409
    Par défaut
    Essayez avec
    sum(if(isnull(actif_net_global) or (actif_net_global=0), last_actif_net_global,actif_net_global))

  5. #5
    Membre expérimenté
    Homme Profil pro
    Inscrit en
    Septembre 2008
    Messages
    940
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 940
    Points : 1 409
    Points
    1 409
    Par défaut Problème de casse dans ma formule
    Je me suis fait avoir, alors je préfère vous le poster !
    Les noms de fonctions dans les expressions calculées ne sont pas sensibles à la casse ( Sum() = sum() = SUM() ) alors que le nom des champs et le nom des variables l'est. Sum(MonChamp) au lieu de sum(MONCHAMP) n'affiche pas d'erreur mais le premier renvoie null ou 0, et le second la somme du champ ...
    Du coup, on peut avoir un tableau croisé dynamique qui annonce fièrement que 3000 + 500 = 3000

  6. #6
    Membre à l'essai
    Profil pro
    Inscrit en
    Juin 2010
    Messages
    31
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2010
    Messages : 31
    Points : 20
    Points
    20
    Par défaut
    Citation Envoyé par FORMULARY Voir le message
    Essayez avec
    sum(if(isnull(actif_net_global) or (actif_net_global=0), last_actif_net_global,actif_net_global))
    sum(if(isnull(actif_net_global) or (actif_net_global=0), last_actif_net_global,actif_net_global))
    ...ça marche!!!!

    Merci bcp pour votre aide
    En revanche je crois que quelquechose m'échappe : je ne sais jamais où mettre le "sum" ds mes formules : devant, derrière, au milieu..J'avoue que j'y vais souvent à tâton...

    ps : en ce qui concerne la casse effectivement il faut faire attention mais j'ai remarqué que QlikView met le champ en rouge au lieu du vert lorsqu'il ne le reconnait pas car mal écrit..

  7. #7
    Membre expérimenté
    Homme Profil pro
    Inscrit en
    Septembre 2008
    Messages
    940
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 940
    Points : 1 409
    Points
    1 409
    Par défaut
    Formule : if(sum(net)=0, last_net, sum(net))
    Traduction :
    La somme des lignes de ma table est calculée pour le champ net.
    Au moment du total, Qlikview évalue le if et donne le résultat.
    Autrement dit :
    Si la somme du champ net=0, alors on affiche last_net, sinon on affiche la somme du champ net.

    Formule : sum(if(isnull(net) or (net=0), last_net,net))
    Traduction :
    Au niveau de chaque ligne, qlikview évalue le if et donne le résultat.
    Qlikview cumule ensuite ce résultat pour afficher le total.
    Autrement dit :
    on affiche la somme de last_net (si pas de ligne net ou si net=0) ou de net (si celui-ci est différent de 0).

    J'espère avoir été suffisamment clair

    PS : Si aucune valeur de net n'existe, qlikview assume une valeur nulle pour une table issue d'une base de données mais assume une chaîne vide "" pour une table interne (Load * INLINE [ ]; ). Vous pouvez donc avoir besoin de tester aussi net="" dans certains cas.

  8. #8
    Membre à l'essai
    Profil pro
    Inscrit en
    Juin 2010
    Messages
    31
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2010
    Messages : 31
    Points : 20
    Points
    20
    Par défaut
    Citation Envoyé par FORMULARY Voir le message
    Formule : if(sum(net)=0, last_net, sum(net))
    Traduction :
    La somme des lignes de ma table est calculée pour le champ net.
    Au moment du total, Qlikview évalue le if et donne le résultat.
    Autrement dit :
    Si la somme du champ net=0, alors on affiche last_net, sinon on affiche la somme du champ net.

    Formule : sum(if(isnull(net) or (net=0), last_net,net))
    Traduction :
    Au niveau de chaque ligne, qlikview évalue le if et donne le résultat.
    Qlikview cumule ensuite ce résultat pour afficher le total.
    Autrement dit :
    on affiche la somme de last_net (si pas de ligne net ou si net=0) ou de net (si celui-ci est différent de 0).

    J'espère avoir été suffisamment clair

    PS : Si aucune valeur de net n'existe, qlikview assume une valeur nulle pour une table issue d'une base de données mais assume une chaîne vide "" pour une table interne (Load * INLINE [ ]; ). Vous pouvez donc avoir besoin de tester aussi net="" dans certains cas.
    merci avec un peu de retard pour les explications

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Totaux dans tableau croise dynamique
    Par evasion dans le forum QlikView
    Réponses: 2
    Dernier message: 09/07/2014, 09h12
  2. somme par ligne dans tableau
    Par enamorada dans le forum Langage
    Réponses: 11
    Dernier message: 05/03/2013, 14h16
  3. Somme des lignes dans un tableau croisé dynamique
    Par lyonnaisdu26 dans le forum QlikView
    Réponses: 0
    Dernier message: 24/10/2011, 09h20
  4. ajouter des lignes dans un tableau dynamique
    Par yviii dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 20/06/2007, 12h15
  5. ajouter des lignes dans un tableau dynamique
    Par yviii dans le forum Windows
    Réponses: 1
    Dernier message: 20/06/2007, 11h28

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo