获取错误“试图获取非对象的属性” 我正在使用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');
}
答案 0 :(得分:2)
您将需要删除->toArray()
,因为您要以数组的形式获取查询结果,例如,这将不允许您使用->id
获取单个属性,从而引发错误。< / p>
删除它会以集合的形式获取结果,使您可以使用foreach
循环对其进行迭代。
$tebtom = Tebtom::orderBy('created_at', 'desc')->get();