如何用循环填充多维数组

时间:2021-04-15 19:19:22

标签: php arrays associative-array

我有一个数组:

$days = array(
    'Sunday',
    'Monday',
    'Tuesday',
    'Wednesday',
    'Thursday',
    'Friday',
    'Saturday'
);

而且我有一个查询女巫正在从数据库中获取我的天数 (day_name,ID); 对于我需要您的帮助:我想用下面的循环填充数组并使其具有关联性。示例结果:

thursday => array(
    'ID' => 1,
    'name' => thursday
),
friday => array(
    'ID' => 1,
    'name' => thursday
),
....eg

我现在的代码:

$query='Query days from database';

foreach($query as $res)
{
    foreach($days as $day)
    {
        if($res == $day)
        {
            // now there I want to put informations
        }
    }
}

2 个答案:

答案 0 :(得分:2)

不需要嵌套循环。将数组初始化为关联数组。然后使用数据库查询中的 name 列索引结果并分配给该元素。

$days = ['sunday' => [], 'monday' => [], ...];
foreach ($query as $row) {
    $days[$row['name']] = $row;
}

答案 1 :(得分:1)

如果您无法初始化数组(如@Barmar Answer 中建议的那样),您需要查找数组键以使用数组覆盖它。喜欢这里:

$days=array('Sunday',
        'Monday',
        'Tuesday',
        'Wednesday',
        'Thursday',
        'Friday',
        'Saturday'
       );
    print_r($days);

//Example
$res[0]['name']="Sunday";
$res[0]['ID']="7";
$res[1]['name']="Monday";
$res[1]['ID']="1";

foreach($res as $k => $v){
$daykey = array_search($res[$k]['name'], $days);
if ($daykey !== false) {
    $days[$daykey]=array($res[$k]['name']=>array('ID'=>$res[$k]['ID'],'name'=>$res[$k]['name']));
} else {
    //do nothing... or whatever
}
} 
print_r($days);