web-dev-qa-db-fra.com

Comment mettre à jour la valeur de clé spécifique dans un tableau associatif en PHP?

J'ai un tableau associatif suivant nommé $data

Array
(
    [0] => Array
        (
            [transaction_user_id] => 359691e27b23f8ef3f8e1c50315cd506
            [transaction_no] => 19500912050218
            [transaction_total_amount] => 589.00
            [transaction_date] => 1335932419
            [transaction_status] => cancelled
        )

    [1] => Array
        (
            [transaction_user_id] => 9def02e6337b888d6dbe5617a172c18d
            [transaction_no] => 36010512050819
            [transaction_total_amount] => 79.00
            [transaction_date] => 1336476696
            [transaction_status] => cancelled
        )

    [2] => Array
        (
            [transaction_user_id] => 9def02e6337b888d6dbe5617a172c18d
            [transaction_no] => 19020512050820
            [transaction_total_amount] => 299.00
            [transaction_date] => 1336476739
            [transaction_status] => cancelled
        )

    [3] => Array
        (
            [transaction_user_id] => 9def02e6337b888d6dbe5617a172c18d
            [transaction_no] => 27050512050821
            [transaction_total_amount] => 79.00
            [transaction_date] => 1336476927
            [transaction_status] => cancelled
        )

    [4] => Array
        (
            [transaction_user_id] => 8e9050a3646c98342b9ba079fba80982
            [transaction_no] => 12070512050822
            [transaction_total_amount] => 129.00
            [transaction_date] => 1336477032
            [transaction_status] => cancelled
        )

)

et je veux convertir la valeur de la clé [transaction_date] au format lisible par l’utilisateur (c’est-à-dire mm/jj/aaaa). Pour cela, j'ai écrit le code suivant dans une fonction qui retourne tout le tableau:

 foreach($data as $value)
        {
            $value[transaction_date]=date('d/m/Y',$value[transaction_date]);
        }

    return $data;

Mon problème est que je reçois le même tableau sans changer la valeur de [transaction_date] pour tous les éléments du tableau. En réalité, un tableau avec les valeurs mises à jour pour [transaction_date] devrait être renvoyé. Quelqu'un peut-il m'aider à résoudre ce problème? Merci d'avance.

39
PHPLover

Changez votre foreach en quelque chose comme ceci, vous n'affectez pas de données à votre variable de retour $data après avoir effectué une opération dessus. 

foreach($data as $key => $value)
{
  $data[$key]['transaction_date'] = date('d/m/Y',$value['transaction_date']);
}

Codepad DEMO.

78
Rikesh

Cela fonctionnera aussi!

foreach($data as &$value) {
  $value['transaction_date'] = date('d/m/Y', $value['transaction_date']);
}

Yay pour des alternatives!

28
user633183

PHP array_walk () function est spécialement conçu pour modifier un tableau.

Essaye ça:

array_walk ( $data, function (&$key) { $key["transaction_date"] = date('d/m/Y',$key["transaction_date"]); } );
12
SJ00

Utilisez la fonction array_walk_recursive pour un tableau multiconfessionnel.

array_walk_recursive($data, function (&$v, $k) { 
    if($k == 'transaction_date'){ 
        $v = date('d/m/Y',$v); 
    } 
});
2
Naveenkumar N
foreach($data as $value)
{
    $value["transaction_date"] = date('d/m/Y',$value["transaction_date"]);
}
return $data;
1
CoBolt