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 :

[Tableaux] Suppression de lignes dans un tableau [FAQ]


Sujet :

Langage PHP

  1. #1
    Membre extrêmement actif Avatar de lodan
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    2 064
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 2 064
    Points : 682
    Points
    682
    Par défaut [Tableaux] Suppression de lignes dans un tableau
    Bonjour,

    J'ai un tableau (array) dans lequel je voudrais retirer les enregistrements qui comporte les caractères "--".

    Est-ce possible ?

    Merci d'avance
    Y a pas, plus on fait, plus on sait. Plus on cherche, plus on sait chercher. Maintenant quant à trouver, c'est autre chose.

  2. #2
    Membre éprouvé Avatar de FCYPBA
    Profil pro
    Inscrit en
    Novembre 2004
    Messages
    745
    Détails du profil
    Informations personnelles :
    Âge : 45
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Novembre 2004
    Messages : 745
    Points : 952
    Points
    952
    Par défaut
    Bonjour,

    Un petit tour dans les fonctions me fait penser que array_filter devrait répondre à tes attentes.

    Pierre

    PS : Il y a un certain nombre de fontions interressante sur les tableaux dans la doc, jette un coup d'oeil
    Pierre
    1. Dans le manuel ( PHP, MySQL,..., rayez la mention inutile), tu te plongeras à deux fois plutôt qu'aucune.
    2. Dans la doc php, tu liras attentivement les sections Chaines de caractères, Tableaux et Système de fichiers
    3. Un code rapide c'est bien, un code maintenable c'est mieux
    ...

    Why was the font tag an orphan ? Because it didn't have a font-family.

  3. #3
    Membre extrêmement actif Avatar de lodan
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    2 064
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 2 064
    Points : 682
    Points
    682
    Par défaut
    Merci pierre, j'avais pensé à cette solution sauf qu'il trouve que "--" n'est pas un argument valide, c'est pourquoi je cherche une autre soluce

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Warning: array_filter() [function.array-filter]: The second argument, '--', should be a valid callback in
    Y a pas, plus on fait, plus on sait. Plus on cherche, plus on sait chercher. Maintenant quant à trouver, c'est autre chose.

  4. #4
    Expert éminent
    Avatar de berceker united
    Profil pro
    SQL
    Inscrit en
    Février 2005
    Messages
    3 488
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : SQL
    Secteur : Finance

    Informations forums :
    Inscription : Février 2005
    Messages : 3 488
    Points : 6 039
    Points
    6 039
    Par défaut
    Oui c'est possible mais je ne pense pas qu'il y a de fonction te faisant le tous clé en main. Un ensemble de fonction arrivera a ton resultat parce que nous ne savons pas si tu veux des index vides ou non.
    Mon avatar ? Ce n'est rien, c'est juste la tête que je fais lorsque je vois un code complètement frappa dingue !...

  5. #5
    Membre éprouvé Avatar de FCYPBA
    Profil pro
    Inscrit en
    Novembre 2004
    Messages
    745
    Détails du profil
    Informations personnelles :
    Âge : 45
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Novembre 2004
    Messages : 745
    Points : 952
    Points
    952
    Par défaut
    Citation Envoyé par lodan
    Merci pierre, j'avais pensé à cette solution sauf qu'il trouve que "--" n'est pas un argument valide, c'est pourquoi je cherche une autre soluce

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Warning: array_filter() [function.array-filter]: The second argument, '--', should be a valid callback in

    Bien sur que ce n'est pas un argument valide, puisque l'argument attendu est une fonction qui déterminera si l'élement doit être garder ou non.

    En gros une fonction dans ce genre :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    function AGarder($a) {
    if ($a == '--' ) return 0;
    return 1;
    }
    Faut lire un peu la doc quand même

    Pierre
    Pierre
    1. Dans le manuel ( PHP, MySQL,..., rayez la mention inutile), tu te plongeras à deux fois plutôt qu'aucune.
    2. Dans la doc php, tu liras attentivement les sections Chaines de caractères, Tableaux et Système de fichiers
    3. Un code rapide c'est bien, un code maintenable c'est mieux
    ...

    Why was the font tag an orphan ? Because it didn't have a font-family.

  6. #6
    Membre extrêmement actif Avatar de lodan
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    2 064
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 2 064
    Points : 682
    Points
    682
    Par défaut
    Oui pardon, j'avais pas fait attention à la doc trop empresser de faire le test.

    Bon effectivement, j'ai fait ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    print_r(array_filter($requete, "AGarder"));
    function AGarder($a) {
    if ($a == '------------------' ) return 0;
    return 1;
    }
    Mais ma table requete est pareil avant et après ce traitement, parce ma ligne de tableau est aussi un tableau

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Array ( [classe] => 3 [classe_libelle] => DEPENSES COURANTES [categorie] => 11 [categorie_libelle] => PERIODICITE [ss_categorie] => 59 [ss_categorie_libelle] => ------------------ ) [1] => Array ( [classe] => 3 [classe_libelle] => [categorie] => 11 [categorie_libelle] => [ss_categorie] => 43 [ss_categorie_libelle] => Alimentation, Entretien ) [2] => Array ( [classe] => 3 [classe_libelle] => [categorie] => 11 [categorie_libelle] => [ss_categorie] => 48 [ss_categorie_libelle] => Autres ) [3] => Array ( [classe] => 3 [classe_libelle] => [categorie] => 11 [categorie_libelle] => [ss_categorie] => 47 [ss_categorie_libelle] => Cadeaux ) [
    Donc ce n'est pas la solution

    En fait, je pense que je vais être obligé d'avoir un tableau en entrée et un tableau en sortie.

    Je lis en entrée et si [ss_categorie_libelle]=------------------ alors je n'écris pas en sortie.
    Y a pas, plus on fait, plus on sait. Plus on cherche, plus on sait chercher. Maintenant quant à trouver, c'est autre chose.

  7. #7
    Membre confirmé
    Inscrit en
    Mai 2002
    Messages
    673
    Détails du profil
    Informations forums :
    Inscription : Mai 2002
    Messages : 673
    Points : 624
    Points
    624
    Par défaut
    Une tite fonction que j'avais faite y'a deja un moment...

    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
     
     
    /*
    Paramètres : 
    - $tab : (array) un tableau
    - $value : valeur a effacer du tableau
    Return : (array) renvoie un nouveau tableau dans lequel ont été effacées toutes les case contenant la valeur $value
    */
    function array_delete($tab, $value)
    {
        $ret = array();
        foreach($tab as $val) 
        { 
            if($val != $value)
                {$ret[] = $val;}
        }
        return $ret;
    }
    Si vous avez un message d'erreur, n'oubliez pas de le lire, la réponse à votre problème est surement dedans !

  8. #8
    Membre extrêmement actif Avatar de lodan
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    2 064
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 2 064
    Points : 682
    Points
    682
    Par défaut
    Merci beaucoup gloubi,

    J'avais fait un test avec ceci
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    foreach($requete as $ligne)
    {
    if($ligne["ss_categorie_libelle"]!='------------------' )
    {$requete2[]=$ligne;}
    }
    Et ça fonctionne très bien, mais je vais passer ça en function maintenant.
    Y a pas, plus on fait, plus on sait. Plus on cherche, plus on sait chercher. Maintenant quant à trouver, c'est autre chose.

  9. #9
    Membre extrêmement actif Avatar de lodan
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    2 064
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 2 064
    Points : 682
    Points
    682
    Par défaut
    Voici la fonction inspiré de celle de gloubi

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    function ArrayDelete($tab, $indice, $value)
    {
        $ret = array();
        foreach($tab as $val) 
        { 
            if($val["$indice"] != $value)
                {$ret[] = $val;}
        }
        return $ret;
    }
    Merci encore et à bientôt sur les posts...
    Y a pas, plus on fait, plus on sait. Plus on cherche, plus on sait chercher. Maintenant quant à trouver, c'est autre chose.

  10. #10
    Membre éprouvé Avatar de FCYPBA
    Profil pro
    Inscrit en
    Novembre 2004
    Messages
    745
    Détails du profil
    Informations personnelles :
    Âge : 45
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Novembre 2004
    Messages : 745
    Points : 952
    Points
    952
    Par défaut
    Petite précision avant que le post ne disparaisse aux oubliettes

    Sur des petits tableaux, ce genre de fonctions peut faire l'affaire, mais la fonction array_filter() est compilé et est donc beaucoup plus rapide.

    Ne réinventer pas la roue

    @+

    PS : Il suffisait de modifier ta fonction
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    function AGarder($a) {
    if ($a['ss_categorie_libelle'] == '------------------' ) return 0;
    return 1;
    }
    Pierre
    1. Dans le manuel ( PHP, MySQL,..., rayez la mention inutile), tu te plongeras à deux fois plutôt qu'aucune.
    2. Dans la doc php, tu liras attentivement les sections Chaines de caractères, Tableaux et Système de fichiers
    3. Un code rapide c'est bien, un code maintenable c'est mieux
    ...

    Why was the font tag an orphan ? Because it didn't have a font-family.

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

Discussions similaires

  1. Probléme avec la suppression de ligne dans un tableau
    Par Tintou dans le forum VBA Word
    Réponses: 6
    Dernier message: 20/08/2009, 15h06
  2. Ajout/Suppression de ligne dans un tableau
    Par Nimothenicefish dans le forum WinDev
    Réponses: 2
    Dernier message: 14/02/2008, 11h56
  3. [Tableaux] Effacer une ligne dans un tableau
    Par gpsevasion dans le forum Langage
    Réponses: 8
    Dernier message: 22/01/2007, 16h38
  4. [Tableaux] Problème de lignes dans un tableau
    Par Perymanu dans le forum Langage
    Réponses: 10
    Dernier message: 18/12/2006, 20h31
  5. [Tableaux] Insertion dynamique ligne dans un tableau
    Par masseur dans le forum Langage
    Réponses: 12
    Dernier message: 28/03/2006, 14h53

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