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 :

Recherche croisé dans tableau muldimension sans array_column [PHP 5.0]


Sujet :

Langage PHP

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    amateur
    Inscrit en
    Mars 2014
    Messages
    28
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France

    Informations professionnelles :
    Activité : amateur

    Informations forums :
    Inscription : Mars 2014
    Messages : 28
    Points : 26
    Points
    26
    Par défaut Recherche croisé dans tableau muldimension sans array_column
    Bonjour,

    le serveur d'entreprise propose php5.0 je ne dispose donc pas d'Array_column, et je ne peux pas demander la MAJ de php.

    j'ai 2 tableaux, par exemple:

    le premier
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    voitureRenault = array ("clio", "meganne", "twingo")
    le second
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    voitureVendu1 = array ([1] => array("secteur" => "1", "type" => "clio", "vendeur"=>"sebastien"), [2] => array("secteur" => "1", "type" => "ds4", "vendeur"=>"julien")
    je n'arrive pas a faire une recherche du type qu'elle voiture n'a pas été vendue.
    je retourne le problème depuis vendredi et je ne trouve aucune solution.

    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
     
    //boucle pour faire tourner les tableaux, car j'ai plusieurs tableau voiture vendu 
    //$d représente le numéro des secteurs 
    //$i commence a  car le premier secteur est 1 et pas 0
     
    for ($i=1; $i <= $d; $i++)
    {
     
    // $l me permet d'afficher le numéro du secteur
    	$l = 0;
     
    	//le tableau voiture vendu est incrémenté du numéro du secteur afin de passer par tous les tableaux
    	foreach(${'voitureVendu'.$i} as $c) {
     
    //affiche le numéro du secteur
    		if ($l == 0) {echo '# '.$c['secteur'].' : <br>'; $l++;}
     
    //je boucle toute les voitures renault pour les chercher dans les voitureVendu
     
    		for ($z=0; $z < count($voitureRenault ); $z++)
    		{
    			if(!in_array($voitureRenault [$z], $c))
    			{	
    			echo ' - voiture restante '.$voitureRenault [$z].'<br>';
    			}
    		}
     
     
     
    	}
     
    }

    Autant ce code fonctionne pour rechercher les voitures vendues autant il ne marche pas pour vérifier si un type de voiture n'a pas été vendu et c'est ce que je cherche a avoir!
    bref auriez vous une idée?

  2. #2
    Membre expert
    Avatar de Spartacusply
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mai 2011
    Messages
    1 723
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mai 2011
    Messages : 1 723
    Points : 3 274
    Points
    3 274
    Par défaut
    La solution est dans les commentaires de la doc php :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    if(!function_exists("array_column"))
    {
     
        function array_column($array,$column_name)
        {
     
            return array_map(function($element) use($column_name){return $element[$column_name];}, $array);
     
        }
     
    }
    Un message utile vous a aidé ? N'oubliez pas le

    www.simplifions.fr - Simplifier vos comptes entre amis !

  3. #3
    Nouveau membre du Club
    Homme Profil pro
    amateur
    Inscrit en
    Mars 2014
    Messages
    28
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France

    Informations professionnelles :
    Activité : amateur

    Informations forums :
    Inscription : Mars 2014
    Messages : 28
    Points : 26
    Points
    26
    Par défaut
    merci beaucoup pour ta réponse et ta rapidité!

    par contre, je ne comprends pas un morceau de code... je sais que j'abuse, mais aurais tu la gentillesse de me le franciser ?
    c'est cette partie:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     function($element) use($column_name){return $element[$column_name];}, $array);

    le reste de la fonction proposé en français:
    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
    //si array colomn n'existe pas cette solution peut fonctionner
    if array_column does not exist the below solution will work.
     
    //si la fonction array_colomn n'existe pas
    if(!function_exists("array_column"))
    {
    //on créé la fonctionn array_column qui fonctionne sur 2 variables le tableau et le nom de la colonne.
        function array_column($array,$column_name)
        {
    // la fonction retourne le traitement du tableau par une fonction
    //cette partie : function($element) use($column_name){return $element[$column_name];}, $array)
    //je la comprends pas du tout!
            return array_map(function($element) use($column_name){return $element[$column_name];}, $array);
     
        }
     
    }

  4. #4
    Membre confirmé
    Homme Profil pro
    Déveleoppeur Web/Mobile
    Inscrit en
    Avril 2013
    Messages
    330
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Déveleoppeur Web/Mobile
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Avril 2013
    Messages : 330
    Points : 545
    Points
    545
    Par défaut
    Je te rassure je vois rarement le "use" en PHP puis te balancer ça en une seule ligne c'est pas très instructif je trouve

  5. #5
    Nouveau membre du Club
    Homme Profil pro
    amateur
    Inscrit en
    Mars 2014
    Messages
    28
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France

    Informations professionnelles :
    Activité : amateur

    Informations forums :
    Inscription : Mars 2014
    Messages : 28
    Points : 26
    Points
    26
    Par défaut
    en effet ça me rassure

    bon, je viens de tester en aveugle (même si j'ai horreur de ne pas comprendre ce que je fais)
    et ça fonctionne...

    merci donc Spartacusply.
    En espérant un jour comprendre

  6. #6
    Membre expert
    Avatar de Spartacusply
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mai 2011
    Messages
    1 723
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mai 2011
    Messages : 1 723
    Points : 3 274
    Points
    3 274
    Par défaut
    Le array_map est une autre manière (plus élégante dirons certains) de faire un foreach sur un tableau (ou plusieurs d'ailleurs).

    On parcours tous les éléments du tableau, pour chaque on retourne un résultat (en l'occurence une colonne de l'élément car on sait que celui-ci est un tableau) que l'on stocke dans un nouveau tableau.

    Le use permet d'utiliser des variables globales dans les fonctions anonymes (une fonction qui n'a pas de nom).

    En espérant t'avoir éclairé.
    Un message utile vous a aidé ? N'oubliez pas le

    www.simplifions.fr - Simplifier vos comptes entre amis !

  7. #7
    Nouveau membre du Club
    Homme Profil pro
    amateur
    Inscrit en
    Mars 2014
    Messages
    28
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France

    Informations professionnelles :
    Activité : amateur

    Informations forums :
    Inscription : Mars 2014
    Messages : 28
    Points : 26
    Points
    26
    Par défaut
    Tu en a fais beaucoup, à moi de lire et apprendre

    super en tout cas, ça fonctionne au poil.

  8. #8
    Expert éminent sénior
    Avatar de rawsrc
    Homme Profil pro
    Dev indep
    Inscrit en
    Mars 2004
    Messages
    6 142
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    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
    Points : 16 545
    Points
    16 545
    Billets dans le blog
    12
    Par défaut
    Citation Envoyé par Spartacusply Voir le message
    Le use permet d'utiliser des variables globales dans les fonctions anonymes (une fonction qui n'a pas de nom).
    Exactement : le use permet d'injecter dans le scope d'une fonction anonyme une ou plusieurs variables (la notion de globale peut réellement porter à confusion et est beaucoup trop restrictive).

    tu peux très bien avoir des fonctions anonymes récursives (qui s'appellent elles-mêmes) et dans ce cas, la fonction s'injecte dans son propre scope comme ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    $factorielle = function($p) use (&$factorielle) // le passage par référence (le & devant le $) est obligatoire ici
    {
        return ($p <= 1) ? 1 : $factorielle($p - 1) * $p;
    };
     
    echo $factorielle(10);

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

Discussions similaires

  1. Réponses: 20
    Dernier message: 09/07/2008, 12h41
  2. recherche chaine dans tableau
    Par mathieu57 dans le forum Langage
    Réponses: 1
    Dernier message: 02/10/2007, 12h29
  3. Recherche valeurs dans tableau par Vlookup
    Par fabibou dans le forum Macros et VBA Excel
    Réponses: 9
    Dernier message: 22/08/2007, 11h51
  4. Recherche croisé dans une base de donnée
    Par elephant13 dans le forum C#
    Réponses: 1
    Dernier message: 24/03/2007, 15h26
  5. recherche lignes dans tableau excel
    Par BODIGUEL dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 18/05/2006, 19h08

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