Filtre un tableau en fonction de la valeur d'une colonne

  Information

Voici un bout de code permettant de nettoyer, filtrer un ensemble d'enregistrements en fonction de la valeur d'une colonne.

  code source classé dans  Tableaux - Array

 
 01    
 02    
 03    
 04    
 05    
 06    
 07    
 08    
 09    
 10    
 11    
 12    
 13    
 14    
 15    
 16    
 17    
 18    
 19    
 20    
 21    
 22    
 23    
 24    
 25    
                               
<?php
/*---------------------------------------------------------------*/
/*
    Titre : Filtre un tableau en fonction de la valeur d'une colonne                                                      
                                                                                                                          
    URL   : https://phpsources.net/code_s.php?id=1065
    Auteur           : sheppy1                                                                                            
    Date édition     : 09 Mars 2019                                                                                       
    Date mise à jour : 02 Sept 2019                                                                                      
    Rapport de la maj:                                                                                                    
    - fonctionnement du code vérifié                                                                                    
*/
/*---------------------------------------------------------------*/
  
    function dictionaryFilterList(array $sourcearray $datastring $column) : 
array
    {
        $new     array_column($data$column);
        $keep     array_diff($new$source);
  
        return array_intersect_key($data$keep);
    }
?>

Exemple :

 
 01    
 02    
 03    
 04    
 05    
 06    
 07    
 08    
 09    
 10    
 11    
 12    
 13    
 14    
 15    
 16    
 17    
 18    
 19    
 20    
 21    
 22    
 23    
 24    
 25    
 26    
 27    
 28    
 29    
                                
<?php
  
    $users = [
        ['first_name' => 'Jed''last_name' => 'Lopez'],
        ['first_name' => 'Carlos''last_name' => 'Granados'],
        ['first_name' => 'Dirty''last_name' => 'Diana'],
        ['first_name' => 'John''last_name' => 'Williams'],
        ['first_name' => 'Betty''last_name' => 'Boop'],
        ['first_name' => 'Dan''last_name' => 'Daniels'],
        ['first_name' => 'Britt''last_name' => 'Anderson'],
        ['first_name' => 'Will''last_name' => 'Smith'],
        ['first_name' => 'Magic''last_name' => 'Johnson'],
    ];
  
    var_dump(dictionaryFilterList(['Dirty''Dan'], $users'first_name'));
  
    // sortie: La fonction à "nettoyer" les 2 éléments (Dirty et Dan)
    [
        ['first_name' => 'Jed''last_name' => 'Lopez'],
        ['first_name' => 'Carlos''last_name' => 'Granados'],
        ['first_name' => 'John''last_name' => 'Williams'],
        ['first_name' => 'Betty''last_name' => 'Boop'],
        ['first_name' => 'Britt''last_name' => 'Anderson'],
        ['first_name' => 'Will''last_name' => 'Smith'],
        ['first_name' => 'Magic''last_name' => 'Johnson']
    ]
?>

          Fonctions du code - Doc officielle PHP

   php.net   Description Versions PHP OUTIL
   array Crée un tableau PHP 4, PHP 5, PHP 7, PHP 8
   array_diff Calcule la différence entre deux tableaux - (PHP 4 >= 4.0.1, PHP 5, PHP 7) PHP 4, PHP 5, PHP 7, PHP 8
   array_intersect_key Calcule l'intersection de deux tableaux en utilisant les clés pour comparaison - (PHP 5 >= 5.1.0) PHP 5, PHP 7, PHP 8
   return Retourne le controle du programme au module appelant. PHP 4, PHP 5, PHP 7, PHP 8
   var_dump Affiche les informations d'une variable PHP 4, PHP 5, PHP 7, PHP 8

   Dites merci aux auteurs pour leurs travail, ça ne coûte rien et ça fait toujours plaisir wink

Présentation de PHP

PHP débutant et initié 50 Tutoriel

Présentation de MySQL

avatar

Sheppy1

  09 Mars 2019

  SOURCE   Télécharger

Information sur les mises à jour

Dernière mise à jour :

    02 Sept 2019
    fonctionnement du code vérifié

3 873 Vues
Compatibilité
PHP 5, 7 et 8+