Excel下载 - Laravel 5.1

时间:2016-06-03 06:58:14

标签: excel export laravel-5.1 maatwebsite-excel

我正在使用名为invoice,invoiceduedates,payments三个表的雄辩查询。所以我在laravel中使用以下查询导出到excel的所有数据。

$pay=Invoice::with('invoiceduedates','payments')->where('Eventcode','=',$eventcode)->get();
$payment='';$invoicepay=array();
foreach($pay as $payble){
            $x=0;$due='';$payment='';$i=0;
            foreach($payble->invoiceduedates as $duedate){
                        $x++;
                        $due .= $duedate->date.','.$duedate->amount;
                        if($x <= count($payble->invoiceduedates)-1){
                        $due.=",";
                        }


            }

            foreach($payble->payments as $paydate){
                        $i++;
                        $payment .= $paydate->adjust_mode.','.$paydate->recieved_amount;
                        if($i <= count($payble->payments)-1){
                        $payment.=",";
                        }


            }

            $invoicepay[]= array_merge(explode(',',$due),explode(',',$payment));
            unset($due);unset($payment);unset($i);unset($x);
}
$export = json_decode(json_encode((array) $invoicepay), true);

          Excel::create('Data', function($excel) use ($export)
             {
                $excel->sheet('Inovice Data', function($sheet) use ($export)
                {
                    $sheet->fromArray($export);

                    $sheet->cells('A1:AE1', function($cells)
                     {

                                $cells->setBackground('#000000');
                                $cells->setFontColor('#fff');

                    });
                    $sheet->row(1, array(
                        'Due Date1','Due Amount1','Due Date2','Due Amount2','AdjustMode1','Rcv Amount1','AdjustMode2','Rcv Amount2'

                     ));
                });
})->download('xlsx');

以下是我的Excel结果:

| Due Date1  | Due Amount1 | Due Date2             | Due Amount2 | AdjustMode1           | Rcv Amount1 | AdjustMode2           | Rcv Amount2 |
|------------|-------------|-----------------------|-------------|-----------------------|-------------|-----------------------|-------------|
| 2016-03-25 | 2000        | 2016-02-29            | 2000        | Overseas Bank Charges | 2000        | Overseas Bank Charges | 2743        |
| 2016-03-31 | 3750        | Overseas Bank Charges | 3708        | Overseas Bank Charges | 2750        |                       |             |

但是这里发生的事情是,当invoiceduedates表中没有第二个截止日期时,Due Date2,Due Amount2的列与Adjust Mode1和RCV Amount1重叠。

我想要的实际excel低于

| Due Date1  | Due Amount1 | Due Date2  | Due Amount2 | AdjustMode1           | Rcv Amount1 | AdjustMode2           | Rcv Amount2 |
|------------|-------------|------------|-------------|-----------------------|-------------|-----------------------|-------------|
| 2016-03-25 | 2000        | 2016-02-29 | 2000        | Overseas Bank Charges | 2000        | Overseas Bank Charges | 2743        |
| 2016-03-31 | 3750        |            |             | Overseas Bank Charges | 3708        | Overseas Bank Charges | 2750        |

当没有第二个截止日期时,我希望这些列为空。如何在foreach循环或excel的标题部分中控制它?请帮忙。

谢谢。

1 个答案:

答案 0 :(得分:1)

您的问题是您没有给$export空格

所以maatwebsite-excel's - &gt; fromArray()函数会将数据逐个放入excel

这些代码可以解决您的问题:(部分代码)

        $x=0;$due='';$payment='';$i=0;
        foreach($payble->invoiceduedates as $duedate){
                    $x++;
                    $due .= $duedate->date.','.$duedate->amount;
                    if($x <= count($payble->invoiceduedates)-1){
                    $due.=",";
                    }


        }
        //added
        if($x == 1){
            $due.=",,"; //add two empty column for  Due Date2 & Due Amount2
        }

        foreach($payble->payments as $paydate){
                    $i++;
                    $payment .= $paydate->adjust_mode.','.$paydate->recieved_amount;
                    if($i <= count($payble->payments)-1){
                    $payment.=",";
                    }


        }
        //added
        if($i == 1){
            $payment.=",,"; //add two empty column for  AdjustMode2 & Rcv Amount2
        }