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 :

Récupérer valeurs de Array dans Array dans un autre Array


Sujet :

Langage PHP

  1. #1
    Membre habitué Avatar de spawns
    Homme Profil pro
    Inscrit en
    Juillet 2004
    Messages
    558
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Juillet 2004
    Messages : 558
    Points : 193
    Points
    193
    Par défaut Récupérer valeurs de Array dans Array dans un autre Array
    Salut à tous,
    le bloque sur un petit souci, j'aurai besoin de récuperer dans des variable pour insertion en bdd par la suite
    les valeurs d'un array se trouvant dans un array qui lui se trouve egalement dans un array.
    il faut passer par un foreach mais je n'y arrive pas.
    voici le tableau :
    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
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    [infos] => Array
                            (
                                [0] => Array
                                    (
                                        [0] => Description
                                        [1] => INFO A RÉCUPÉRER ICI
                                    )
    
                                [1] => Array
                                    (
                                        [0] => Situation
                                        [1] => INFO A RÉCUPÉRER ICI
                                    )
    
                                [2] => Array
                                    (
                                        [0] => Opération Commercial
                                        [1] => INFO A RÉCUPÉRER ICI
                                    )
    
                                [3] => Array
                                    (
                                        [0] => Qualité
                                        [1] => INFO A RÉCUPÉRER ICI
                                    )
    
                                [4] => Array
                                    (
                                        [0] => Prestation
                                        [1] => INFO A RÉCUPÉRER ICI
                                    )
    
                                [5] => Array
                                    (
                                        [0] => Accès
                                        [1] => INFO A RÉCUPÉRER ICI
                                    )
    
                            )
    Merci d'avance de votre aide
    Cdt

  2. #2
    Rédacteur/Modérateur
    Avatar de andry.aime
    Homme Profil pro
    Inscrit en
    Septembre 2007
    Messages
    8 391
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Ile Maurice

    Informations forums :
    Inscription : Septembre 2007
    Messages : 8 391
    Points : 15 059
    Points
    15 059
    Par défaut
    Bonjour,

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    foreach($info as $array){
    	 echo $array[1]."<br />";	
    }
    A+.

  3. #3
    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
    Plus exactement :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    // $tab est la variable tableau
    $infos = $tab['infos'];
    foreach($infos as $array){
    	 echo $array[1]."<br />";	
    }
    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]

  4. #4
    Membre habitué Avatar de spawns
    Homme Profil pro
    Inscrit en
    Juillet 2004
    Messages
    558
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Juillet 2004
    Messages : 558
    Points : 193
    Points
    193
    Par défaut
    ok merci,
    par contre il faut que je mette chaque resulats dans une variable differente
    pour pouvoir l'inserer en bdd
    si je fait cela ça ne fonctionne pas :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    $infos = $tab['infos'];
    foreach($infos as $array){
    	 $des = $array[1];
    	 $situ= $array[1];
    	 $ope= $array[1];
    	 $qua= $array[1];
    	 $acc= $array[1];	
    }
    $sql="INSERT INTO ...
    comment faire ?

  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 : 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
    Un foreach va faire autant de tours de boucles qu'il ya de lignes dans ton tableau. Donc logiquement il faudrait affecter une variable par tour de boucle.
    Comment sais-tu quelle valeur devrait aller dans quelle variable ?
    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 habitué Avatar de spawns
    Homme Profil pro
    Inscrit en
    Juillet 2004
    Messages
    558
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Juillet 2004
    Messages : 558
    Points : 193
    Points
    193
    Par défaut
    par rapport au tableau justement.
    je récupère ce tableau par rapport a un flux et je doit insérer les données en bdd

    le 1er resulat du array doit aller dans $dec
    le 2éme resulat du array doit aller dans $situ
    le 3éme resulat du array doit aller dans $ope

    Etc...

  7. #7
    Rédacteur/Modérateur
    Avatar de andry.aime
    Homme Profil pro
    Inscrit en
    Septembre 2007
    Messages
    8 391
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Ile Maurice

    Informations forums :
    Inscription : Septembre 2007
    Messages : 8 391
    Points : 15 059
    Points
    15 059
    Par défaut
    Si tu utilises PDO, et que tes données sont biens structurées, tu peux utiliser quelque chose du genre:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     $params = array();
    foreach($infos as $array){
    	 $params = $array[1];
    };
     
    $stmt = $db->prepare( "insert into nom_table(a,b,c,d) values(?,?,?,?)");
    foreach ($params as $idx => $value) 
         $stmt->bindValue($idx, $value);
    }
    $stmt->execute();

  8. #8
    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
    @Andry : attention, faute de frappe :$params[] = $array[1];

    Sinon, si tu as un nombre de champs raisonnables et que l'ordre est fixe, tu le fais directement à la main :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    $infos = $tab['infos'];
    $des = $infos[0][1];
    $situ= $infos[1][1];
    $ope=  $infos[2][1];
    $qua=  $infos[3][1];
    $acc=  $infos[4][1];
    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]

  9. #9
    Membre habitué Avatar de spawns
    Homme Profil pro
    Inscrit en
    Juillet 2004
    Messages
    558
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Juillet 2004
    Messages : 558
    Points : 193
    Points
    193
    Par défaut
    Citation Envoyé par Celira Voir le message
    @Andry : attention, faute de frappe :$params[] = $array[1];

    Sinon, si tu as un nombre de champs raisonnables et que l'ordre est fixe, tu le fais directement à la main :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    $infos = $tab['infos'];
    $des = $infos[0][1];
    $situ= $infos[1][1];
    $ope=  $infos[2][1];
    $qua=  $infos[3][1];
    $acc=  $infos[4][1];
    Désolé andry.aime mais je n'utilise pas PDO mais merci pour l'info


    Oui Celira c'est ça, nombre de champs fixe, 5 dans mon cas donc nickel ça marche.

    Merci

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 06/03/2012, 09h11
  2. [ZF 1.7] Récupérer valeur d'un enregistrement saisi dans un autre formulaire
    Par CinePhil dans le forum Zend_Form
    Réponses: 24
    Dernier message: 11/02/2011, 09h42
  3. [XL-2003] Récupérer valeur de ligne selon recherche dans tableau
    Par Lufia dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 05/11/2009, 13h02
  4. Réponses: 1
    Dernier message: 13/08/2009, 13h58
  5. Réponses: 3
    Dernier message: 28/09/2007, 16h58

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