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 :

Variation par rapport à une période précédente dans un TCD


Sujet :

QlikView

  1. #1
    Membre régulier
    Inscrit en
    Septembre 2007
    Messages
    226
    Détails du profil
    Informations forums :
    Inscription : Septembre 2007
    Messages : 226
    Points : 78
    Points
    78
    Par défaut Variation par rapport à une période précédente dans un TCD
    Bonjour,

    Mon TCD calcul les sommes par commercial et par période, je cherche a calculer la variation de cette somme par rapport à la période précédente pour chaque commercial avec un set analysis comme par exemple,

    sum({$<periode={(periode)-1}>}vente)
    avez vous une idée?

  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,

    Supposons que vous ayez ces données :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    Data:
    LOAD * INLINE [
    Commercial, Periode, Valeur
    Bob, 1, 1
    Bob, 2, 2
    Bob, 3, 3
    Mike, 1, 10
    Mike, 2, 20
    Mike, 3, 30
    ];
    Si votre tableau contient en dimension uniquement les commerciaux, et que vous souhaitez que l'utilisateur filtre sur une période, vous pouvez utiliser l'expression
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Sum({$ <Periode={'$(=only(Periode) - 1)'}>} Valeur)
    pour connaitre la valeur de la période précédente.

    En revanche, si vous utilisez la dimension "Periode" dans votre graph, il ne sera pas possible de jouer avec dans les Set Analysis : en effet, le Set Analysis est appliqué à l'expression avant que le calcul soit fait ligne par ligne.

    Pour obtenir ce que vous souhaitez, vous avez 2 solutions :
    - Utiliser la fonction "above()", qui permet de calculer une expression selon la valeur de dimension précédente. Cela ne fonctionnera que si "Periode" est la dernière dimension.

    - Utiliser une dimension décorrélée du modèle :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    DimPeriode:
    LOAD 
    DISTINCT Periode AS DimPeriode
    RESIDENT Data
    ORDER BY Periode ASC;
    Dans le graph, au lieu d'utiliser "Periode" comme dimension, on utilise "DimPeriode".
    Pour avoir la valeur correspondante à la période, on met l'expression
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sum(if(Periode = DimPeriode, Valeur))
    et pour avoir la valeur correspondante à la période précédente, on met l'expression
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sum(if(Periode + 1 = DimPeriode, Valeur))
    .

    Avec cette méthode, on peut mettre les dimensions dans l'ordre qu'on veut dans le graph. L'inconvénient est que le graph sera un peu plus long à calculer, car QV sera obligé de tester une égalité pour chaque ligne du graph.

  3. #3
    Membre régulier
    Inscrit en
    Septembre 2007
    Messages
    226
    Détails du profil
    Informations forums :
    Inscription : Septembre 2007
    Messages : 226
    Points : 78
    Points
    78
    Par défaut
    Merci pour la reponse,

    petit problème je n'arrive pas à intégrer le code dans le script faut il le mettre après le chargement de la table? et depuis quel fichier?

    cordialement.

  4. #4
    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
    Oui, il faut mettre le code dans le script, après le chargement de votre table.
    Etant donné que le "LOAD" de ma dimension séparée se base sur une table "RESIDENT", c'est forcément après.

    et depuis quel fichier?
    Je ne comprends pas la question.
    Vous chargez vos données depuis vos fichiers / base de données.

  5. #5
    Membre régulier
    Inscrit en
    Septembre 2007
    Messages
    226
    Détails du profil
    Informations forums :
    Inscription : Septembre 2007
    Messages : 226
    Points : 78
    Points
    78
    Par défaut
    Pour le chargement Effectivement j'ai pas bien vu DATA.

    Toutefois, la formule ne renvoi pas de données,

  6. #6
    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
    Citation Envoyé par arnest Voir le message
    Toutefois, la formule ne renvoi pas de données,
    Quelle formule ?
    Avec quelles dimensions dans le graphique ?

  7. #7
    Nouveau membre du Club
    Homme Profil pro
    PM IT BI
    Inscrit en
    Juillet 2014
    Messages
    41
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : PM IT BI
    Secteur : Industrie Pharmaceutique

    Informations forums :
    Inscription : Juillet 2014
    Messages : 41
    Points : 38
    Points
    38
    Par défaut
    Le plus simple c'est de ce créer une dimension périodicité avec :

    Mois_de_dim_temps
    Mois_de_dim_fait
    Type_de_periode

    Tu peux faire facilement du mensuel, du cumule mobile, de l'annuel ...

    Ton set analyse filtre le type de période


    Par contre cela nécessite un peu de code pour faire ta dimension

  8. #8
    Membre régulier
    Inscrit en
    Septembre 2007
    Messages
    226
    Détails du profil
    Informations forums :
    Inscription : Septembre 2007
    Messages : 226
    Points : 78
    Points
    78
    Par défaut
    Mon code est basique
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    DATA:
    LOAD Periode, 
         Commercial, 
         Valeur
    FROM
    [C:\Users\rr\Desktop\clas.xlsx]
    (ooxml, embedded labels, table is Feuil1);

  9. #9
    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
    Il faut donc :
    - créer une dimension séparée sur la période
    - modifier le graph pour qu'il utilise cette dimension
    - modifier l'expression du graph pour y rajouter la formule qui va bien pour prendre la période courante ou la précédente

    (cf. mon premier post)

  10. #10
    Membre régulier
    Inscrit en
    Septembre 2007
    Messages
    226
    Détails du profil
    Informations forums :
    Inscription : Septembre 2007
    Messages : 226
    Points : 78
    Points
    78
    Par défaut
    C'est assez compliqué pour moi , si c'est possible un peu plus de détail pour avancer,

    Merci infiniment

  11. #11
    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
    Créer une dimension séparée :
    Ajouter ces lignes dans le script après le Load Data :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    Periodes:
    LOAD DISTINCT Periode AS DimPeriode
    RESIDENT DATA
    ORDER BY Periode ASC;
    Ca va créer une table Periodes contenant un champ DimPeriode

    Modifier ensuite le graphe pour utiliser DimPeriode comme champ de dimension.

    Modifier l'expression du graphe et saisir :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sum(IF(Periode + 1 = DimPeriode, Valeur))
    Attention dans la saisie des formules : QV est "Case Sensitive" :
    Saisir "Période" ou "periode" à la place de "Periode" peut provoquer un mauvais calcul ...

  12. #12
    Membre régulier
    Inscrit en
    Septembre 2007
    Messages
    226
    Détails du profil
    Informations forums :
    Inscription : Septembre 2007
    Messages : 226
    Points : 78
    Points
    78
    Par défaut
    Ca ne marche pas toujours, j'ai essayé
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sum( {$<month= {$(#=Only(month)-1)}>} Valeur)
    sachant que month est une variable que je calcule lors du chargement mais c'est la même chose,

  13. #13
    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
    Alors...

    - Si vous utilisez une dimension séparée du modèle, il faut utiliser une expression du genre
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sum(IF(Periode + 1 = DimPeriode, Valeur))
    (comme indiqué dans mon premier post).

    - Ce n'est pas une bonne idée de nommer vos variables avec le même nom qu'un dimension de votre modèle.

    - La fonction "only()" attend une dimension, pas une variable.

    - Quelle sont les dimensions de votre graphique ?

Discussions similaires

  1. [XL-2010] Pourcentage d'une valeur par rapport au sous total dans un TCD
    Par Denis_67 dans le forum Excel
    Réponses: 6
    Dernier message: 10/06/2015, 12h23
  2. [WebI Xi3] Requete dynamique par rapport à une réponse utilisateur dans une invite
    Par Jenesépa dans le forum Débuter
    Réponses: 0
    Dernier message: 21/08/2013, 09h56
  3. Réponses: 3
    Dernier message: 27/01/2010, 12h37
  4. Réponses: 3
    Dernier message: 20/04/2007, 14h18
  5. tri par rapport à une liste dans la clause where
    Par umbakrail dans le forum MS SQL Server
    Réponses: 5
    Dernier message: 19/07/2006, 11h32

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