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

BIRT Discussion :

[2.2.0][Designer] Moyenne pondérée dans un "cross tab"


Sujet :

BIRT

  1. #1
    Membre averti
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    octobre 2005
    Messages
    215
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : octobre 2005
    Messages : 215
    Points : 435
    Points
    435
    Par défaut [2.2.0][Designer] Moyenne pondérée dans un "cross tab"
    Bonjour,
    Je souhaite faire un rapport contenant un tableau croisé. Ce tableau comportera trois mesures : montants, quantités et totaux.
    Je veux que pour les totaux et les quantités la valeur affichée soit la somme des lignes correspondantes (jusqu'ici pas de problème) et que pour les montants ce soit la moyenne des montants pondérée par les quantités... et c'est là qu'arrivent les ennuis.
    Si j'ai comme données :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    quantité    montant     total
    10          10          100
    20          25          500
    Je veux obtenir dans mon tableau croisé :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    quantité    montant     total
    30          20          600
    J'ai donc essayé de définir ma mesure comme étant :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    dataSetRow["total"]/dataSetRow["quantite"]
    avec comme fonction d'aggrégation la somme mais cela n'est pas satisfaisant car j'obtiens :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    quantité    montant     total
    30          35          600
    En fait, il me fait alors que je voudrais
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sum(total)/sum(quantite)
    J'ai également essayé de diviser les mesures quantité et total entre elles (ce qui revient à diviser les données aggrégées mais j'obtiens une erreur comme quoi BIRT n'a pas pu créer le cube : pas totalement illogique car cela revient à lui dire d'utiliser le cube pour construire le cube).
    Avez-vous une idée sur la manière de procéder pour obtenir le résultat souhaité ?
    En vous remerciant par avance et en espérant avoir été clair (n'hésitez pas à me demander plus de détails).

    EDIT : J'ai trouvé un début de solution
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    data["total"]/data["quantite"]
    dans un dynamic text mais ça a l'inconvénient de ne pas pouvoir se positionner "correctement". En effet, cela va faire une présentation du genre :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    ________________
    |montant |.....|
    |--------|total|
    |quantité|.....|
    ----------------
    alors que je souhaiterais tout aligner donc [montant|quantité|total] (qui a dit que j'étais chi*** ? )
    « Pourquoi faire simple quand on peut faire compliqué ? » (Deuxième principe fondamental de la logique Shadok)

  2. #2
    Nouveau membre du Club
    Homme Profil pro
    Développeur .NET
    Inscrit en
    septembre 2006
    Messages
    36
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : septembre 2006
    Messages : 36
    Points : 30
    Points
    30
    Par défaut
    Bonjour
    je pense,
    tu crée un agrega pour chaque attribut a part dans ton cross tab.
    ensuite, tu utilse un data à partir de palette, et dans son edit data binding tu aura une experession de la forme.

    data["total_Group1/total"]/data["quantite_Group2/quantite"]



    Citation Envoyé par giragu03 Voir le message
    Bonjour,
    Je souhaite faire un rapport contenant un tableau croisé. Ce tableau comportera trois mesures : montants, quantités et totaux.
    Je veux que pour les totaux et les quantités la valeur affichée soit la somme des lignes correspondantes (jusqu'ici pas de problème) et que pour les montants ce soit la moyenne des montants pondérée par les quantités... et c'est là qu'arrivent les ennuis.
    Si j'ai comme données :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    quantité    montant     total
    10          10          100
    20          25          500
    Je veux obtenir dans mon tableau croisé :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    quantité    montant     total
    30          20          600
    J'ai donc essayé de définir ma mesure comme étant :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    dataSetRow["total"]/dataSetRow["quantite"]
    avec comme fonction d'aggrégation la somme mais cela n'est pas satisfaisant car j'obtiens :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    quantité    montant     total
    30          35          600
    En fait, il me fait alors que je voudrais
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sum(total)/sum(quantite)
    J'ai également essayé de diviser les mesures quantité et total entre elles (ce qui revient à diviser les données aggrégées mais j'obtiens une erreur comme quoi BIRT n'a pas pu créer le cube : pas totalement illogique car cela revient à lui dire d'utiliser le cube pour construire le cube).
    Avez-vous une idée sur la manière de procéder pour obtenir le résultat souhaité ?
    En vous remerciant par avance et en espérant avoir été clair (n'hésitez pas à me demander plus de détails).

    EDIT : J'ai trouvé un début de solution
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    data["total"]/data["quantite"]
    dans un dynamic text mais ça a l'inconvénient de ne pas pouvoir se positionner "correctement". En effet, cela va faire une présentation du genre :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    ________________
    |montant |.....|
    |--------|total|
    |quantité|.....|
    ----------------
    alors que je souhaiterais tout aligner donc [montant|quantité|total] (qui a dit que j'étais chi*** ? )

  3. #3
    Membre averti
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    octobre 2005
    Messages
    215
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : octobre 2005
    Messages : 215
    Points : 435
    Points
    435
    Par défaut
    Bonjour,
    Je te remercie pour ta réponse mais pourrais-tu m'éclairer un petit plus car je n'arrive pas à faire ce que tu me dis.
    J'essaie de créer une aggregation pour mes attributs dans mon cross-tab mais cela ne marche pas.
    D'autre part, si j'ajoute un data qui n'est pas créé à partir de mon cube, j'obtiens la présentation
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    ________________
    |montant |.....|
    |--------|total|
    |quantité|.....|
    ----------------
    Je continue à chercher de mon côté et je vous tiens au courant.
    EDIT : Je me suis inspiré de ta technique (enfin si j'ai bien compris ce que tu suggérais): j'ai créé une mesure "bidon" pour les montants (avec une méthode de calcul bidon), j'insère cette mesure dans le tableau et au final je remplace la expression (measure["montant"]) par data["total"]/data["quantite"]
    C'est de la bidouille donc si quelqu'un a mieux, je suis preneur.
    Merci pour ton aide lotfilol
    « Pourquoi faire simple quand on peut faire compliqué ? » (Deuxième principe fondamental de la logique Shadok)

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

Discussions similaires

  1. [Access] Comment faire un moyenne pondérée dans une requete ?
    Par megapacman dans le forum Langage SQL
    Réponses: 3
    Dernier message: 27/01/2007, 10h23
  2. Requête sql, moyenne pondérée
    Par ouiffi dans le forum Langage SQL
    Réponses: 2
    Dernier message: 26/07/2006, 12h03
  3. URGENT : Moyenne pondéré?
    Par cquadjul dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 24/04/2006, 20h08
  4. Moyenne pondérée
    Par Tijee dans le forum Langage SQL
    Réponses: 7
    Dernier message: 28/01/2006, 22h13
  5. [C#][Designer] Méthode executée dans property en DesignMode
    Par backseatgreg dans le forum Windows Forms
    Réponses: 5
    Dernier message: 03/01/2006, 12h00

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