Como converter valores de matriz para minúsculas no PHP?


132

Como posso converter todos os valores em uma matriz para minúsculas no PHP?

Algo como array_change_key_case?

Respostas:


355

use array_map():

$yourArray = array_map('strtolower', $yourArray);

Caso você precise minúscula matriz aninhada (por Yahya Uddin ):

$yourArray = array_map('nestedLowercase', $yourArray);

function nestedLowercase($value) {
    if (is_array($value)) {
        return array_map('nestedLowercase', $value);
    }
    return strtolower($value);
}

16
te amo, te amo, te amo
Craig Wayne

Uma boa resposta única. Obrigado
José Ayrám 04/04/19

@Vit usemb_strtolower
user3841429

@ user3841429 mb_strtolower não ajudou. PHP7.2.
Vit

2
@Vit Você usou como se segue? $yourArray = array_map('mb_strtolower', $yourArray);Acabei de verificar e funcionou para cirílico
user3841429

27

Apenas para completar: você também pode usar array_walk:

array_walk($yourArray, function(&$value)
{
  $value = strtolower($value);
});

Dos documentos PHP:

Se o retorno de chamada precisar trabalhar com os valores reais da matriz, especifique o primeiro parâmetro do retorno de chamada como referência. Em seguida, quaisquer alterações feitas nesses elementos serão feitas na própria matriz original.

Ou diretamente via foreachloop usando referências :

foreach($yourArray as &$value)
  $value = strtolower($value);

Observe que esses dois métodos alteram a matriz "no local", enquanto array_mapcria e retorna uma cópia da matriz, o que pode não ser desejável no caso de matrizes muito grandes.


Para matrizes multidimensionais, use array_walk_recursive(). Também mb_strtolower()porque o mundo é multilíngue.
Kodeart 21/06/19

8

Você pode usar array_map (), definir o primeiro parâmetro como 'strtolower' (incluindo as aspas) e o segundo parâmetro como $ lower_case_array.


5

Se você deseja minúsculos todos os valores em uma matriz aninhada , use o seguinte código:

function nestedLowercase($value) {
    if (is_array($value)) {
        return array_map('nestedLowercase', $value);
    }
    return strtolower($value);
}

Assim:

[ 'A', 'B', ['C-1', 'C-2'], 'D']

retornaria:

[ 'a', 'b', ['c-1', 'c-2'], 'd']   

3

array_change_value_case

por continuar

    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
  )

)

2

array_map()é o método correto. Mas, se você deseja converter valores de matriz específicos ou todos os valores de matriz em minúsculas, um por um, é possível usar strtolower().

for($i=0; $i < count($array1); $i++) {
    $array1[$i] = strtolower($array1[$i]);
}

1

Solução AIO / Recursiva / Unicode | UTF-8 | Multibyte suportado!

/**
 * 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;
}

Exemplo:

$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);

Resultado

    [
    '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'
    ]
]

1

Você não diz se sua matriz é multidimensional. Se for, o array_map não funcionará sozinho. Você precisa de um método de retorno de chamada. Para matrizes multidimensionais, tente 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);

0

`$ Color = array ('A' => 'Azul', 'B' => 'Verde', 'c' => 'Vermelho');

$ strtolower = array_map ('strtolower', $ Cor);

$ strtoupper = array_map ('strtoupper', $ Cor);

print_r ($ strtolower); print_r ($ strtoupper); `


-2

Você também pode usar uma combinação de array_flip()e array_change_key_case(). Veja este post


4
Os dados da matriz são perdidos após a chamada array_flip()se a matriz contiver valores duplicados.
Pang
Ao utilizar nosso site, você reconhece que leu e compreendeu nossa Política de Cookies e nossa Política de Privacidade.
Licensed under cc by-sa 3.0 with attribution required.