array_keys
<<<
array_map array_merge_recursive
>>>

6.2 Tableaux
6 Référence des fonctions
 Manuel PHP

Introduction
Pré-requis
Installation
Configuration à l'exécution
Types de ressources
Constantes pré-définies
Voir aussi
array_change_key_case
array_chunk
array_combine
array_count_values
array_diff_assoc
array_diff_key
array_diff_uassoc
array_diff_ukey
array_diff
array_fill
array_filter
array_flip
array_intersect_assoc
array_intersect_key
array_intersect_uassoc
array_intersect_ukey
array_intersect
array_key_exists
array_keys
->array_map
array_merge_recursive
array_merge
array_multisort
array_pad
array_pop
array_product
array_push
array_rand
array_reduce
array_reverse
array_search
array_shift
array_slice
array_splice
array_sum
array_udiff_assoc
array_udiff_uassoc
array_udiff
array_uintersect_assoc
array_uintersect_uassoc
array_uintersect
array_unique
array_unshift
array_values
array_walk_recursive
array_walk
array
arsort
asort
compact
count
current
each
end
extract
in_array
key
krsort
ksort
list
natcasesort
natsort
next
pos
prev
range
reset
rsort
shuffle
sizeof
sort
uasort
uksort
usort

6.2.27 array_map()Applique une fonction sur les éléments d'un tableau

[ Exemples avec array_map ]   PHP 4 >= 4.0.6, PHP 5

array  array_map ( callback   callback , array   arr1 , array   ... )

array_map retourne un tableau contenant tous les éléments du tableau arr1 , après leur avoir appliqué la fonction callback . Le nombre de paramètres de la fonction callback doit être égal au nombre de tableaux passés dans la fonction array_map , dans les arguments supplémentaires ... .

Exemple avec array_map

<?php
  
function cube($n) {
      return
$n*$n*$n;
  }
  
$a = array(1, 2, 3, 4, 5);
  
$b = array_map("cube", $a);
  
print_r($b);
?>

array_map : utilisation de plusieurs tableaux

<?php
  
function parle_espagnol($n, $m) {
      return
"Le nombre $n se dit $m en espagnol";
  }

  function
map_espagnol($n, $m) {
   return array(
$n => $m);
  }

  
$a = array(1, 2, 3, 4, 5);
  
$b = array("uno", "dos", "tres", "cuatro", "cinco");
  
$c = array_map("parle_espagnol", $a, $b);
  
print_r($c);
?>

Généralement, lors de l'utilisation de plusieurs tableaux, ils doivent être d'égale longueur, car la fonction de callback est appliquée de manière similaire à tous les tableaux. Si les tableaux sont de tailles inégales, les plus petits seront complétés avec des éléments vides.

Une utilisation intéressante de cette fonction est la construction de tableaux de tableaux, facilement réalisée en passant la valeur NULL comme nom de fonction de callback.

Création d'un tableau de tableaux

<?php
$a
= array(1, 2, 3, 4, 5);
$b = array("one", "two", "three", "four", "five");
$c = array("uno", "dos", "tres", "cuatro", "cinco");
$d = array("un", "deux","trois","quatre","cinq");

$d = array_map(null, $a, $b, $c, $d);
print_r($d);
?>

Voir aussi array_filter , array_reduce , array_walk et information à propos de callback type.

<< array_map >>
array_keys Tableaux array_merge_recursive