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

PHP & Base de données Discussion :

Traitement 2 tableaux remplie par bdd [MySQL]


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre du Club
    Profil pro
    Développeur Web
    Inscrit en
    Avril 2012
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Avril 2012
    Messages : 7
    Par défaut Traitement 2 tableaux remplie par bdd
    Bonjour , tout d'abord j'espère avoir poster au bon endroit , ma demande est plutôt simple mais j'ai la tête dedans depuis tellement longtemps que je commence à avoir du mal.
    Donc comme dit dans le sujet j'ai 2 tableaux qui se remplisse de cette manière :
    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
    $montant_cour = array();
    $montant = array();
    // $pourcentage = array();
     
     $result4 = $wpdb->get_results("select nbr_dossiers,annee_ca,mois_ca from indic_dossiers WHERE annee_dossier IN (".$date_en_cour.")");
    foreach($result4 as $val2)
    {
    	array_push($montant_cour , $val2->nbr_dossiers); //reléve tout les nombres de dossiers de l'année date_en_cour
    }
    $montant_cour = implode(",", $montant_cour);
     
     
    $result5 = $wpdb->get_results("select nbr_devis from indic_dossiers WHERE annee_dossier IN (".$anne_desirer.")");
    foreach($result5 as $val3) 
    {
    	array_push($montant, $val3->nbr_devis);		//reléve tout les devis de dossiers de l'année anne_desirer
     
    }
    $montant_ca = implode(",", $montant);
    je précise je suis sous wordpress actuellement pour ceux qui se poserai des question au sujet des $wpdb-> les requètes reste simple
    mon problème avec c'est 2 tableaux qui ressemble a quelque choses comme sa array(125 , 232 , 123) array2 (20, 35 , 110)
    mon but est de faire un pourcentage je m'explique :
    un tableau contient le nombre de dossier réalisé et l'autre le nombre de devis réaliser et je voudrai donc calculer le pourcentage des devis qui ont était concrétisé ( pour ceux qui ne comprennent pas : (20/125)*100 = 16% voilà et donc je voudrai faire cette opération avec chacune des valeur de mes deux tableaux après plusieurs essai je n'obtent toujours pas le bon résultat quelqu'un peut-il m'aider?

    petite précision : les implodes me sont nécessaire car après les valeurs sont placé dans un plugin pour être affiché sous forme graphique et donc je dois y mettre mes valeur avec une virgule entre chacune d'entre elles

  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 : 40
    Localisation : France

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

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Par défaut
    Un array_map à plusieurs tableaux ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $pourcentages = array_map(create_function('$part, $total', 'return ($part/$total)*100;'), $montant_ca, $montant_cour);
    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
    Expert confirmé
    Avatar de rawsrc
    Homme Profil pro
    Dev indep
    Inscrit en
    Mars 2004
    Messages
    6 142
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Dev indep

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 142
    Billets dans le blog
    12
    Par défaut
    Citation Envoyé par Celira Voir le message
    Un array_map à plusieurs tableaux ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $pourcentages = array_map(create_function('$part, $total', 'return ($part/$total)*100;'), $montant_ca, $montant_cour);
    Toutafé

    Une autre façon de faire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    <?php
     
    $a = array(20, 35, 110);
    $b = array(125, 232, 123);
     
    $p100 = array_map(function($p) { return $p[0]/$p[1]*100; }, array_map(null, $a, $b));
     
    ?>

  4. #4
    Membre du Club
    Profil pro
    Développeur Web
    Inscrit en
    Avril 2012
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Avril 2012
    Messages : 7
    Par défaut
    Bonjour , et merci d'avoir répondu à ma question mais :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $pourcentages = array_map(create_function('$dossier, $devis', 'return ($dossier/$devis)*100;'), $montant_cour, $montant_ca);
    Voilà avec ceci j'ai une erreur il me dit que l'argument n°2 n'est pas un tableau pourtant
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     $result5 = $wpdb->get_results("select nbr_devis from indic_dossiers WHERE annee_dossier IN (".$anne_desirer.")");
    								foreach($result5 as $val3) 
     
    								{
     
    									array_push($montant, $val3->nbr_devis);		//reléve tout les devis de dossiers de l'année anne_desirer
     
    								}
     
    								//Ici je dois faire un pourcentage par rapport au nombre de dossier et des devis réalisés
    								$montant_ca = implode(",", $montant);
    Je ré-édite car j'ai résolu le soucis j'ai supprimer le implode car il ajouter un caractère dans le tableau cela fonctionne où du moin j'ai cru que cela fonctionner j'ai bien mes 12 valeurs mais : 0,0,0,0,0,0,0,0,0,0,0,0

  5. #5
    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 : 40
    Localisation : France

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

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Par défaut
    Ben si tu fais un implode dessus, ce n'est plus un tableau
    Donc il te faut 2 variables : le tableau et la chaine après implode
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $ligne_montant_cour = implode(",", $montant_cour);
    Et sinon, ben il faut voir les valeurs des 2 tableaux. Fais un print_r dessus, histoire qu'on voit ce qu'il ya dedans...
    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]

  6. #6
    Membre du Club
    Profil pro
    Développeur Web
    Inscrit en
    Avril 2012
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Avril 2012
    Messages : 7
    Par défaut
    merci rawsrc et à Celira , pour votre rapidité et votre "Clairvoyance" ( au sens ou vous n'avez pas mit longtemps à trouver une solution)
    Problème résolu grâce au print_r j'ai trouvé d'ou venez mon erreur j'ai mal placé mon code et donc on ne rentré pas dans ma boucle et donc pas de résultat .
    Maintenant je ne sais pas si je devrai faire un autre post mais j'ai une autre requête en faite je récupère des données des valeurs par mois et donc j'ai enregistrer dans ma base, le mois correspondant a chaque valeur mais je voudrai récupéré les valeurs suivant l'ordre des mois que j'ai choisi c'est possible ?

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

Discussions similaires

  1. Réponses: 39
    Dernier message: 19/08/2015, 18h37
  2. [Débutant] ComboBox remplis par une BDD access
    Par Flora2013 dans le forum C#
    Réponses: 1
    Dernier message: 04/04/2013, 13h40
  3. [MySQL] Tableau rempli par une BDD
    Par xender dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 17/05/2006, 11h58
  4. Traitement des tableaux de word avec VBA: balise index
    Par Invité dans le forum VBA Word
    Réponses: 20
    Dernier message: 29/11/2005, 15h39
  5. Traitement des champs memo par DBGrid
    Par Sydaze dans le forum Bases de données
    Réponses: 4
    Dernier message: 18/04/2005, 09h24

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