我正在尝试对数组中的数据运行清理作业,特别是将纪元时间转换为 YYYY-MM-DD.
我最初尝试过这个功能:
foreach ($data as $row) {$row['eventdate'] = date('Y-m-d', $row['eventdate']);}echo '';打印_r($数据);echo '</pre>';
但是,当我输出数据时,foreach 循环并没有更新数据.
以下 for 循环确实有效:
for ($i=0; $i为什么第一个循环失败而第二个循环成功?他们不一样吗?
当您以目前的方式使用 foreach 循环时,foreach ($data as $row){, $row 被按值"使用,而不是按引用".
尝试通过将 & 添加到 $row 来更新引用:
foreach ($data as &$row) {$row['eventdate'] = date('Y-m-d', $row['eventdate']);或者,您可以使用键/值方法:
foreach ($data as $index => $row) {$data[$index]['eventdate'] = date('Y-m-d', $row['eventdate']);I'm trying to run a clean up job on data in an array, specifically converting epoch time to YYYY-MM-DD.
I tried this function originally:
foreach ($data as $row) {
$row['eventdate'] = date('Y-m-d', $row['eventdate']);
}
echo '<pre>';
print_r($data);
echo '</pre>';
However the foreach loop didn't update the data when I output it.
The following for loop did work:
for ($i=0; $i<count($data); $i++) {
$data[$i]['eventdate'] = date('Y-m-d', $data[$i]['eventdate']);
}
Why did the first loop fail and the second work? Aren't they the same?
When you're using a foreach loop in the way you currently are, foreach ($data as $row) {, $row is being used "by-value", not "by-reference".
Try updating to a reference by adding the & to the $row:
foreach ($data as &$row) {
$row['eventdate'] = date('Y-m-d', $row['eventdate']);
Or, you can use the key/value method:
foreach ($data as $index => $row) {
$data[$index]['eventdate'] = date('Y-m-d', $row['eventdate']);
这篇关于为什么我不能用 foreach 循环更新数组中的数据?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持html5模板网!
MySQLi准备好的语句&foreach 循环MySQLi prepared statement amp; foreach loop(MySQLi准备好的语句amp;foreach 循环)
mysqli_insert_id() 是从整个服务器还是从同一用户获Is mysqli_insert_id() gets record from whole server or from same user?(mysqli_insert_id() 是从整个服务器还是从同一用户获取记录?)
PHP MySQLi 无法识别登录信息PHP MySQLi doesn#39;t recognize login info(PHP MySQLi 无法识别登录信息)
mysqli_select_db() 需要 2 个参数mysqli_select_db() expects exactly 2 parameters(mysqli_select_db() 需要 2 个参数)
Php mysql pdo 查询:用查询结果填充变量Php mysql pdo query: fill up variable with query result(Php mysql pdo 查询:用查询结果填充变量)
MySQLI 28000/1045 用户“root"@“localhost"的访问MySQLI 28000/1045 Access denied for user #39;root#39;@#39;localhost#39;(MySQLI 28000/1045 用户“root@“localhost的访问被拒绝)