通过循环提供关联数组

时间:2016-11-28 00:43:05

标签: php associative-array

我尝试提供关联数组,但它始终只保留最后插入的值。

$turmas = array(
        'cod_disciplina' => '', 
        'cod_turma'      => '', 
        'hr_inicio'      => '', 
        'hr_fim'         => '', 
        'dia_semana'     => ''
        );

foreach($temp as $t)
        {
           $result = Horario::select('cod_disciplina', 'cod_turma', 'hr_inicio', 'hr_fim', 'dia_semana')
            ->where('cod_disciplina', $t->cod_disciplina)
            ->where('cod_turma', $t->cod_turma)
            ->where('ano_semestre', $ano_semestre)->get();

            foreach($result as $r)
            {
                $turmas['cod_disciplina'] = $r->cod_disciplina;
                $turmas['cod_turma'] = $r->cod_turma;
                $turmas['hr_inicio'] = $r->hr_inicio;
                $turmas['hr_fim']    = $r->hr_fim;
                $turmas['dia_semana']    = $r->dia_semana;

            }            
        }  

数组$turmas始终只保留最后一个插入。我知道它覆盖了一些东西,但我不知道如何修复它。

这是我期望作为最终结果的一个例子。

Array
(
    [0] => Array
        (
            [cod_disciplina] => DPS1000
            [cod_turma] => 11
            [hr_inicio] => 15:30:00
            [hr_fim] => 17:30:00
            [dia_semana] => Terça-feira
        )

    [1] => Array
        (
            [cod_disciplina] => DPS1000
            [cod_turma] => 11
            [hr_inicio] => 13:30:00
            [hr_fim] => 15:30:00
            [dia_semana] => Quarta-feira
        )

    [2] => Array
        (
            [cod_disciplina] => DPS1002
            [cod_turma] => 10
            [hr_inicio] => 08:30:00
            [hr_fim] => 12:30:00
            [dia_semana] => Quarta-feira
        )

    [3] => Array
        (
            [cod_disciplina] => DPS1003
            [cod_turma] => 10
            [hr_inicio] => 07:30:00
            [hr_fim] => 09:30:00
            [dia_semana] => Segunda-feira
        )

    [4] => Array
        (
            [cod_disciplina] => DPS1003
            [cod_turma] => 10
            [hr_inicio] => 10:30:00
            [hr_fim] => 10:30:00
            [dia_semana] => Segunda-feira
        )

)

1 个答案:

答案 0 :(得分:2)

你想要的是一个数组数组,所以在你的foreach中将新的$turma数组附加到$turmas数组。

$turmas = [];

foreach($temp as $t) {
    $result = Horario::select('cod_disciplina', 'cod_turma', 'hr_inicio', 'hr_fim', 'dia_semana')
    ->where('cod_disciplina', $t->cod_disciplina)
    ->where('cod_turma', $t->cod_turma)
    ->where('ano_semestre', $ano_semestre)->get();

    foreach($result as $r) {
        $turma = [];
        $turma['cod_disciplina'] = $r->cod_disciplina;
        $turma['cod_turma'] = $r->cod_turma;
        $turma['hr_inicio'] = $r->hr_inicio;
        $turma['hr_fim'] = $r->hr_fim;
        $turma['dia_semana'] = $r->dia_semana;
        $turmas[] = $turma;
    }
}