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

Langage PHP Discussion :

Créer un tableau pour afficher un graphique


Sujet :

Langage PHP

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Février 2012
    Messages
    135
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2012
    Messages : 135
    Points : 69
    Points
    69
    Par défaut Créer un tableau pour afficher un graphique
    Je cherche à créer un tableau pour afficher un graphique.

    J'ai des régions : Bretagne, Provence, Aquitaine.
    J'ai des chiffres d'affaires réalisés dont je peux récupérer la région.

    Objectif : Aboutir à un graphique Camembert avec la répartition du CA par Région.

    Je fais une boucle PHP pour afficher toutes les ventes, j'ai donc le CA par ligne.

    Comment puis-je construire un Tableau qui additionne les valeurs trouvés par Région?

    Ou créer un premier tableau avec ces valeurs, et à la fin additionner toutes les valeurs de la même région ?

    Bretagne => 1200 €
    Aquitaine => 1320 €
    Bretagne => 600 €


    Merci.

  2. #2
    Modératrice
    Avatar de Celira
    Femme Profil pro
    Développeuse PHP/Java
    Inscrit en
    Avril 2007
    Messages
    8 633
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 39
    Localisation : France

    Informations professionnelles :
    Activité : Développeuse PHP/Java
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Points : 16 372
    Points
    16 372
    Par défaut
    Pour la somme, le plus simple serait probablement de le faire directement en SQL (mais ça dépend de la structure de ta table)

    Je te conseille de jeter un oeil à ce tuto : Création de graphes statistiques et géométriques avec PHP et la librairie GD
    Modératrice PHP
    Aucun navigateur ne propose d'extension boule-de-cristal : postez votre code et vos messages d'erreurs. (Rappel : "ça ne marche pas" n'est pas un message d'erreur)
    Cherchez un peu avant poser votre question : Cours et Tutoriels PHP - FAQ PHP - PDO une soupe et au lit !.

    Affichez votre code en couleurs : [CODE=php][/CODE] (bouton # de l'éditeur) et [C=php][/C]

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Février 2012
    Messages
    135
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2012
    Messages : 135
    Points : 69
    Points
    69
    Par défaut
    En fait, je ne peux pas le faire directement en SQL car j'ai un calcul des montants qui se fait à la volée pour une partie.

    Donc j'ai commencé comme cela.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
       $stat_fdo = array(); 
       $stat_cash_net = array(); 
       $res=query($sql);
       while($row=fetch($res))
       {
          $stat_fdo[$region["valeur"]][]=$mavaleur;
          $stat_cash_net[$region["valeur"]][]=$mavaleur;
     
       }
     
    	print_r($stat_cash_net);
    	print_r($stat_fdo);
    En faisant un print_r j'obtiens ceci

    Array ( [CHOLETAISE] => Array ( [0] => 0 [1] => 15000 [2] => 7000 [3] => 0 ) [ANJOU] => Array ( [0] => 36000 ) [NORMANDIE MAINE] => Array ( [0] => 10000 ) )

    J'ai bien la région et pour chacune d'elle tous les montants.

    Comment puis-je faire pour obtenir le total de chaque région ?

    Merci.

  4. #4
    Modératrice
    Avatar de Celira
    Femme Profil pro
    Développeuse PHP/Java
    Inscrit en
    Avril 2007
    Messages
    8 633
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 39
    Localisation : France

    Informations professionnelles :
    Activité : Développeuse PHP/Java
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Points : 16 372
    Points
    16 372
    Par défaut
    Si toutes les valeurs de chaque région sont dans un tableau, utilise array_sum.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    $stat_total = array();
    foreach ($stat_fdo as $region => $valeurs) {
      $stat_total[$region] = array_sum($valeurs);
    }
    Modératrice PHP
    Aucun navigateur ne propose d'extension boule-de-cristal : postez votre code et vos messages d'erreurs. (Rappel : "ça ne marche pas" n'est pas un message d'erreur)
    Cherchez un peu avant poser votre question : Cours et Tutoriels PHP - FAQ PHP - PDO une soupe et au lit !.

    Affichez votre code en couleurs : [CODE=php][/CODE] (bouton # de l'éditeur) et [C=php][/C]

  5. #5
    Membre éprouvé Avatar de redoran
    Homme Profil pro
    Développeur-Amateur
    Inscrit en
    Juin 2010
    Messages
    1 346
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : Algérie

    Informations professionnelles :
    Activité : Développeur-Amateur
    Secteur : Santé

    Informations forums :
    Inscription : Juin 2010
    Messages : 1 346
    Points : 1 031
    Points
    1 031
    Par défaut requêtes d'agrégats
    c'est faisable en sql sans passé par les array.
    http://dev.mysql.com/doc/refman/5.0/...functions.html

Discussions similaires

  1. Créer un tableau pour afficher les données d'une requête.
    Par BILANGA dans le forum Général JavaScript
    Réponses: 8
    Dernier message: 13/10/2009, 12h04
  2. Problème pour afficher un graphique
    Par poche dans le forum Pentaho
    Réponses: 1
    Dernier message: 07/03/2009, 19h28
  3. créer un bouton pour afficher une image
    Par wawrint dans le forum Général JavaScript
    Réponses: 12
    Dernier message: 11/07/2008, 12h08
  4. Quel composant pour afficher un graphique ?
    Par tipiweb dans le forum Composants VCL
    Réponses: 6
    Dernier message: 18/06/2005, 17h39
  5. Réponses: 7
    Dernier message: 21/10/2004, 09h13

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