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 :

Calcul d'expression se basant sur mes dimensions


Sujet :

QlikView

  1. #1
    Membre à l'essai
    Inscrit en
    Mars 2013
    Messages
    17
    Détails du profil
    Informations forums :
    Inscription : Mars 2013
    Messages : 17
    Points : 15
    Points
    15
    Par défaut Calcul d'expression se basant sur mes dimensions
    Bonjour,

    Je bute sur le problème technique suivant.
    J'ai un tableau croisé dynamique à 3 dimensions (A, B, C) et avec 2 expressions. Je veux rajouter une nouvelle expression qui me permettrait d'identifier la ligne avec la plus grosse valeur en fonction de ma première dimension. Voici l'exemple ci-dessous:

    distinct / sum / Best sum A
    A B1 C1 20 / 220
    A B1 C2 30 / 250
    A B1 C3 40 / 860
    A B1 C4 20 / 520
    A B2 C1 10 / 840
    A B2 C2 80 / 960 / X
    A B2 C3 40 / 950
    A1 B1 C1 30 / 750
    A1 B1 C2 80 / 120
    A1 B1 C3 90 / 140
    A1 B1 C4 60 / 260
    A1 B2 C2 40 / 280
    A1 B2 C3 50 / 950 / X
    A1 B3 C7 30 / 250
    A1 B3 C8 20 / 360

    Je veux donc avoir une formule me permettant d'avoir un X sur la plus grosse valeur de mon expression SUM en fonction de la dimension A.
    Donc dans cet exemple pour la dimension A ayant la valeur A ma plus forte valeur étant 960 c'est cette ligne qui doit avoir un X.
    Pour A1 ce sera 950.

    J'ai creusé la fonction dimensionality() et aggr() sans arriver à trouver la combinaison.

    Merci d'avance de votre aide,

  2. #2
    Modérateur

    Inscrit en
    Octobre 2006
    Messages
    1 649
    Détails du profil
    Informations forums :
    Inscription : Octobre 2006
    Messages : 1 649
    Points : 2 529
    Points
    2 529
    Billets dans le blog
    6
    Par défaut
    Bonjour,

    Je ne comprends pas comment vous faites pour avoir un "sum" à 220.
    Je ne comprends pas non plus ce que vous voulez dire par "la plus grosse valeur en fonction de ma première dimension".


    Je vais essayer de répondre avec les éléments que j'ai compris.

    Supposons que nous ayons les données suivantes :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    Data:
    LOAD * INLINE [
    DimA, DimB, DimC, Value1, Value2
    A, B1, C1, 20, 220
    A, B1, C2, 30, 250
    A, B1, C3, 40, 860
    A, B1, C4, 20, 520
    A, B2, C1, 10, 840
    A, B2, C2, 80, 960
    A, B2, C3, 40, 950
    A1, B1, C1, 30, 750
    A1, B1, C2, 80, 120
    A1, B1, C3, 90, 140
    A1, B1, C4, 60, 260
    A1, B2, C2, 40, 280
    A1, B2, C3, 50, 950
    A1, B3, C7, 30, 250
    A1, B3, C8, 20, 360
    ];

    Pour obtenir le graph suivant

    je mets les 3 dimensions et les expressions suivantes :
    pour avoir la somme (qui sera donc agrégée par A, B et C).


    Pour obtenir la plus grosse valeur pour un "A", je fais
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    max(total <DimA> aggr(sum(Value2), DimA, DimB, DimC))
    qui dit :
    - je fais la somme pour chaque A / B / C
    - je prends la valeur maximum pour chaque A


    Enfin, l'expression
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    if(sum(Value2) = max(total <DimA> aggr(sum(Value2), DimA, DimB, DimC)), 'X', '')
    met le "X" là où il faut.
    (une simple affichage différent --gras, fond de couleur, ...-- serait peut être plus approprié)

Discussions similaires

  1. Réponses: 0
    Dernier message: 04/07/2012, 15h47
  2. Réponses: 2
    Dernier message: 03/11/2011, 21h10
  3. Réponses: 1
    Dernier message: 15/07/2008, 20h54
  4. Réponses: 2
    Dernier message: 08/07/2008, 11h28
  5. Réponses: 18
    Dernier message: 29/02/2008, 11h41

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