错误尝试获取非对象laravel 5.4和maatwebsite 2.1.0的属性

时间:2018-11-03 21:21:34

标签: php laravel maatwebsite-excel

获取错误“试图获取非对象的属性” 我正在使用laravel 5.4,php 5.6和maatwebsite 2.1.0 获取excel文件,这是代码

function excel()
    {
        $tebtom = Tebtom::orderBy('created_at', 'desc')->get()->toArray();
        $tebtom_array[] = array('رقم الموضوع', 'إسم الراسل', 'رقم الهاتف', 'البريد الإلكترونى', 'رقم العضوية', 'المرفق', 'القصة', 'تاريخ الإضافة');
        foreach ($tebtom as $tebtomItem)
        {
            $tebtom_array[] = array(
                'رقم الموضوع' => $tebtomItem->id,
                'إسم الراسل' => $tebtomItem->Name,
                'رقم الهاتف' => $tebtomItem->mobile,
                'البريد الإلكترونى' => $tebtomItem->email,
                'رقم العضوية' => $tebtomItem->membership,
                'المرفق' => $tebtomItem->attach,
                'القصة' => $tebtomItem->story,
                'تاريخ الإضافة' => $tebtomItem->created_at
            );
        }
        Excel::create('بيانات المواضيع', function($excel) use ($tebtom_array){
            $excel->setTitle('بيانات المواضيع');
            $excel->sheet('بيانات المواضيع', function($sheet) use ($tebtom_array){
                $sheet->fromArray($tebtom_array, null, 'A1', false, false);
            });
        })->download('xlsx');
    }

1 个答案:

答案 0 :(得分:2)

您将需要删除->toArray(),因为您要以数组的形式获取查询结果,例如,这将不允许您使用->id获取单个属性,从而引发错误。< / p>

删除它会以集合的形式获取结果,使您可以使用foreach循环对其进行迭代。

$tebtom = Tebtom::orderBy('created_at', 'desc')->get();