Comment puis-je convertir toutes les valeurs d'un tableau en minuscules en PHP?
Quelque chose comme array_change_key_case
?
utilisez array_map()
:
$yourArray = array_map('strtolower', $yourArray);
Juste pour compléter: vous pouvez aussi utiliser array_walk
:
array_walk($yourArray, function(&$value)
{
$value = strtolower($value);
});
À partir de PHP docs:
Si callback doit fonctionner avec les valeurs réelles du tableau, spécifiez le premier paramètre de callback comme référence. Ensuite, toutes les modifications apportées à ces éléments seront effectuées dans le tableau d'origine lui-même.
Ou directement via foreach
loop using references :
foreach($yourArray as &$value)
$value = strtolower($value);
Notez que ces deux méthodes changent le tableau "en place", alors que array_map
crée et retourne une copie du tableau, ce qui peut ne pas être souhaitable dans le cas de très grands tableaux.
Vous pouvez utiliser array_map (), définir le premier paramètre sur 'strtolower' (y compris les guillemets) et le second sur $ lower_case_array.
Si vous souhaitez mettre en minuscule toutes les valeurs d'un tableau imbriqué , utilisez le code suivant:
function nestedLowercase($value) {
if (is_array($value)) {
return array_map('nestedLowercase', $value);
}
return strtolower($value);
}
Alors:
[ 'A', 'B', ['C-1', 'C-2'], 'D']
retournerais:
[ 'a', 'b', ['c-1', 'c-2'], 'd']
array_change_value_case
par continue
function array_change_value_case($array, $case = CASE_LOWER){
if ( ! is_array($array)) return false;
foreach ($array as $key => &$value){
if (is_array($value))
call_user_func_array(__function__, array (&$value, $case ) ) ;
else
$array[$key] = ($case == CASE_UPPER )
? strtoupper($array[$key])
: strtolower($array[$key]);
}
return $array;
}
$arrays = array ( 1 => 'ONE', 2=> 'TWO', 3 => 'THREE',
'FOUR' => array ('a' => 'Ahmed', 'b' => 'basem',
'c' => 'Continue'),
5=> 'FIVE',
array('AbCdeF'));
$change_case = array_change_value_case($arrays, CASE_UPPER);
echo "<pre>";
print_r($change_case);
Array ( [1] => one [2] => two [3] => three [FOUR] => Array ( [a] => ahmed [b] => basem [c] => continue ) [5] => five [6] => Array ( [0] => abcdef ) )
array_map()
est la bonne méthode. Toutefois, si vous souhaitez convertir des valeurs de tableau spécifiques ou toutes les valeurs de tableau en lettres minuscules, vous pouvez utiliserstrtolower()
.
for($i=0; $i < count($array1); $i++) {
$array1[$i] = strtolower($array1[$i]);
}
Vous ne dites pas si votre tableau est multi-dimensionnel. Si tel est le cas, array_map ne fonctionnera pas seul. Vous avez besoin d'une méthode de rappel. Pour les tableaux multidimensionnels, essayez array_change_key_case .
// You can pass array_change_key_case a multi-dimensional array,
// or call a method that returns one
$my_array = array_change_key_case(aMethodThatReturnsMultiDimArray(), CASE_UPPER);
Solution AIO/Récursive/Unicode | UTF-8 | Multibyte supporté!
/**
* Change array values case recursively (supports utf8/multibyte)
* @param array $array The array
* @param int $case Case to transform (\CASE_LOWER | \CASE_UPPER)
* @return array Final array
*/
function changeValuesCase ( array $array, $case = \CASE_LOWER ) : array {
if ( !\is_array ($array) ) {
return [];
}
/** @var integer $theCase */
$theCase = ($case === \CASE_LOWER)
? \MB_CASE_LOWER
: \MB_CASE_UPPER;
foreach ( $array as $key => $value ) {
$array[$key] = \is_array ($value)
? changeValuesCase ($value, $case)
: \mb_convert_case($array[$key], $theCase, 'UTF-8');
}
return $array;
}
Exemple:
$food = [
'meat' => ['chicken', 'fish'],
'vegetables' => [
'leafy' => ['collard greens', 'kale', 'chard', 'spinach', 'lettuce'],
'root' => ['radish', 'turnip', 'potato', 'beet'],
'other' => ['brocolli', 'green beans', 'corn', 'tomatoes'],
],
'grains' => ['wheat', 'rice', 'oats'],
];
$newArray = changeValuesCase ($food, \CASE_UPPER);
Sortie
[
'meat' => [
0 => 'CHICKEN'
1 => 'FISH'
]
'vegetables' => [
'leafy' => [
0 => 'COLLARD GREENS'
1 => 'KALE'
2 => 'CHARD'
3 => 'SPINACH'
4 => 'LETTUCE'
]
'root' => [
0 => 'RADISH'
1 => 'TURNIP'
2 => 'POTATO'
3 => 'BEET'
]
'other' => [
0 => 'BROCOLLI'
1 => 'GREEN BEANS'
2 => 'CORN'
3 => 'TOMATOES'
]
]
'grains' => [
0 => 'WHEAT'
1 => 'RICE'
2 => 'OATS'
]
]