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 :

Restriction de données dans un tableau


Sujet :

QlikView

  1. #1
    Membre du Club
    Femme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2019
    Messages
    52
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Avril 2019
    Messages : 52
    Points : 44
    Points
    44
    Par défaut Restriction de données dans un tableau
    Bonjour

    En pièce jointe mon tableau de type croisé dynamique.

    Je souhaite sélectionner uniquement les lignes où la colonne PointCde est différente de 0 et la colonne Qté sorties = 0.

    Pour gérer la sélection sur la qté sortie, j'ai ajouté une expression FLAGPURGE. Voici l'expression :
    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
    20
    21
    22
    23
    24
    25
    26
    27
    if(
    (Sum({< MoisNum={$(=Max(MoisNum))} >} QteVentes) 
    + Sum({< MoisNum={$(=(Max(MoisNum)-1))}, Mois=, Annee= >} QteVentes) 
    + Sum({< MoisNum={$(=(Max(MoisNum)-2))}, Mois=, Annee= >} QteVentes)
    + Sum({< MoisNum={$(=(Max(MoisNum)-3))}, Mois=, Annee= >} QteVentes)
    + Sum({< MoisNum={$(=(Max(MoisNum)-4))}, Mois=, Annee= >} QteVentes)
    + Sum({< MoisNum={$(=(Max(MoisNum)-5))}, Mois=, Annee= >} QteVentes)
    + Sum({< MoisNum={$(=(Max(MoisNum)-6))}, Mois=, Annee= >} QteVentes)
    + Sum({< MoisNum={$(=(Max(MoisNum)-7))}, Mois=, Annee= >} QteVentes)
    + Sum({< MoisNum={$(=(Max(MoisNum)-8))}, Mois=, Annee= >} QteVentes)
    + Sum({< MoisNum={$(=(Max(MoisNum)-9))}, Mois=, Annee= >} QteVentes)
    + Sum({< MoisNum={$(=(Max(MoisNum)-10))}, Mois=, Annee= >} QteVentes)
    + Sum({< MoisNum={$(=(Max(MoisNum)-11))}, Mois=, Annee= >} QteVentes)
     
    + Sum({< MoisNum={$(=Max(MoisNum))} >} QteOD) 
    + Sum({< MoisNum={$(=(Max(MoisNum)-1))}, Mois=, Annee= >} QteOD) 
    + Sum({< MoisNum={$(=(Max(MoisNum)-2))}, Mois=, Annee= >} QteOD)
    + Sum({< MoisNum={$(=(Max(MoisNum)-3))}, Mois=, Annee= >} QteOD)
    + Sum({< MoisNum={$(=(Max(MoisNum)-4))}, Mois=, Annee= >} QteOD)
    + Sum({< MoisNum={$(=(Max(MoisNum)-5))}, Mois=, Annee= >} QteOD)
    + Sum({< MoisNum={$(=(Max(MoisNum)-6))}, Mois=, Annee= >} QteOD)
    + Sum({< MoisNum={$(=(Max(MoisNum)-7))}, Mois=, Annee= >} QteOD)
    + Sum({< MoisNum={$(=(Max(MoisNum)-8))}, Mois=, Annee= >} QteOD)
    + Sum({< MoisNum={$(=(Max(MoisNum)-9))}, Mois=, Annee= >} QteOD)
    + Sum({< MoisNum={$(=(Max(MoisNum)-10))}, Mois=, Annee= >} QteOD)
    + Sum({< MoisNum={$(=(Max(MoisNum)-11))}, Mois=, Annee= >} QteOD))<>0
    ,0,1)
    c'est-à-dire que si mon calcul de qté sortie est différent de 0, FLAGPURGE = 0 (je ne prends pas), et sinon FLAGPURGE = 1 (je prends).

    Ensuite dans chaque expression, j'ai ajouté une condition dans la définition. Exemple pour l'expression Stock :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    if(FLAGPURGE=1,
    FirstSortedValue({< Mois=, Annee=, ORIGINE={'STOCK'}>} ArticleQteStock, -NoligTrans))
    => Cela fonctionne très bien.

    MAIS je ne parviens pas à sélectionner les lignes où le Point Cde est différent de 0.
    J'ai tenté plusieurs choses :
    • ajouter la condition dans FLAGPURGE : ça ne fonctionne pas
    • activer une condition dans la dimension d'ArticlePointCde : if(ArticlePointCde<>0,1,0)


    ça ne marche pas.

    Avez vous une solution ?
    MERCI
    Fichiers attachés Fichiers attachés

  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,

    Vous pouvez ajouter à votre Set Analysis la condition suivante :
    qui dira "ne pas prendre ceux dont ArticlePointCde = 0".


    Au passage, je pense que
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Sum({< MoisNum={$(=(Max(MoisNum)-10))}, Mois=, Annee= >} QteOD)
    ne retournera pas ce que vous attendez à moins que "MoisNum" ne corresponde pas au numéro de mois.
    Si on est en février et que MoisNum vaut "2", vous sélectionnerez donc les MoisNum qui sont égaux à "-8".

    A mon avis, il serait mieux d'avoir un champ de date au premier jour du mois généré par exemple avec
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    num(makedate(Annee, Mois)) AS AnneeMoisNum
    et d'utiliser un Set Analysis du genre
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    =Sum({$ <AnneeMoisNum={"<=$(=num(max(AnneeMoisNum))) >=$(=num(addmonths(max(AnneeMoisNum), -11)))"}, MoisNum=, Mois=, Annee= >} QteVentes)

  3. #3
    Membre du Club
    Femme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2019
    Messages
    52
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Avril 2019
    Messages : 52
    Points : 44
    Points
    44
    Par défaut
    Bonjour

    Merci pour les tuyaux, ça fonctionne, super !!

    Par contre, j'ai un autre tableau à créer pour obtenir les stocks dormants. Je dois effectuer plusieurs sélections/dé-sélections sur mes dimensions, et sur les expressions.

    Voici les sélections ou dé-sélections à faire sur les dimensions :
    - Dimension Dépôt <> A04 : c'est OK je l'ai géré dans le Set Analysis de l'expression
    - Dimension Regroupement d'activité <> LS : c'est OK je l'ai géré dans le Set Analysis de l'expression
    - Dimension Type article = P1 ou P2 : c'est OK je l'ai géré dans le Set Analysis de l'expression

    - Dimension Activité <> 4P si dimension Dépôt = A01 ou A20 ou A28 ou A51
    comment le gérer ? est-ce possible aussi dans le set analysis ?

    Voici mon expression :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    FirstSortedValue({< Mois=, Annee=, ORIGINE={'STOCK'},%KEY_Depot-={'A04'}, %KEY_RgptActivité-={'LS'}, %KEY_TypeArticle={'P1','P2'} >} ArticleQteStock, -NoligTrans)

  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
    - Dimension Activité <> 4P si dimension Dépôt = A01 ou A20 ou A28 ou A51
    comment le gérer ? est-ce possible aussi dans le set analysis ?
    C'est possible, mais assez compliqué.
    Il faut avoir un identifiant unique et jouer avec les fonctions P() et E().

    Exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    unique_id=P({$ <Dépot={'A01', 'A20', 'A28', 'A51'}>} unique_id)*P({$ <Activité-={'4P'}>} unique_id)
    qui veut dire "on prend les ID qui sont l'intersection des ID dont "dépot" est "A01 ou A20 ou ..." et des ID dont "Activité" est différent de "4P"".

Discussions similaires

  1. [MySQL] Stocker des données dans un tableau
    Par LadyArwen dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 02/02/2006, 10h40
  2. Réponses: 3
    Dernier message: 11/01/2006, 17h44
  3. Réponses: 3
    Dernier message: 05/12/2005, 02h30
  4. Trier les données dans 1 tableau par ordre décroissant
    Par Blunet dans le forum VB 6 et antérieur
    Réponses: 8
    Dernier message: 23/11/2005, 09h56
  5. [XML-XSLT] Données dans un tableau
    Par Hoegaarden dans le forum XSL/XSLT/XPATH
    Réponses: 5
    Dernier message: 10/12/2004, 15h51

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