9
arrayextract
array_extract
SYNOPSIS
array_extract($arr, $keys)
DESCRIPTION
array_extract
retourne un tableau associatif des éléments de $arr
dont les clés sont listés dans $keys
.
Si $keys
est un tableau associatif, les éléments dans le tableau retourné sont renommés avec les valeurs associées aux clés.
EXEMPLE
Pour extraire une sélection de valeurs :
php > require 'library/dump.php';
php > require 'library/arrayextract.php';
php > $arr=array('name' => 'frasq', 'mail' => 'frasq@frasq.org', 'locale' => 'fr');
php > dump(array_extract($arr, array('name', 'mail', 'website')));
array(2) {
["name"] => string(5) "frasq"
["mail"] => string(15) "frasq@frasq.org"
}
Pour extraire des valeurs tout en renommant les clés dans le tableau retourné :
php > dump(array_extract($arr, array('name' => 'username', 'mail' => 'usermail')));
array(3) {
["username"] => string(5) "frasq"
["usermail"] => string(15) "frasq@frasq.org"
}
CODE
- function array_extract($arr, $keys) {
- $r = array();
- foreach ($arr as $k => $v) {
- if (in_array($k, $keys)) {
- $r[$k] = $v;
- }
- else if (array_key_exists($k, $keys)) {
- $r[$keys[$k]] = $v;
- }
- }
- return $r;
- }
Commentaires