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.
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']);
}
Cela fonctionnera aussi!
foreach($data as &$value) {
$value['transaction_date'] = date('d/m/Y', $value['transaction_date']);
}
Yay pour des alternatives!
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"]); } );
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);
}
});
foreach($data as $value)
{
$value["transaction_date"] = date('d/m/Y',$value["transaction_date"]);
}
return $data;