Laravel Excel将变量传递给出口商

时间:2018-12-20 09:49:31

标签: php laravel laravel-excel

我正在使用Laravel Excel 3.1尝试使用两个参数导出文件

web.php {路由文件}

Route::post('/Download', 'Controller@Download');

和我的控制器

public function Download(Request $request)
{
$StartDate  =  Input::get('StartDate');
$EndDate = Input::get('EndDate');
$exporter = app()->makeWith(UsersExport::class, compact('StartDate','EndDate'));
return $exporter->download('Summary Detail.xlsx');
}

userExporter.php

class UsersExport implements FromQuery, WithHeadings,ShouldAutoSize
{
use Exportable;
protected $StartDate,$EndDate;
public function __construct(String  $StartDate,String $EndDate)
{
$this->StartDate = $StartDate;
$this->EndDate = $EndDate;
}
public function query()
{
return databaseReceipt::query()
->whereDate('created_at', '>=', $this->StartDate)
->whereDate('created_at', '<=', $this->EndDate)
->select('id','servicename',"created_at");
}
}

当我使用静态变量(例如“ 00:00 01/04/2017”和“ 00:00 01/01/2018”)作为开始日期和结束日期时,它工作正常,这导致传递变量不起作用< / p>

2 个答案:

答案 0 :(得分:0)

对不起,我想出了什么问题<<我想,那天我很累,因为解决方法很简单

功能下载中

$S = date('Y-m-d H:i:s', strtotime(strtr($request->StartDate, '/', '-')));
$E = date('Y-m-d H:i:s', strtotime(strtr($request->EndDate, '/', '-')));
return (new UsersExport($S,$E))->download('invoices.xlsx');

只是为了明确我的错误,是因为日期格式不同。 顺便说一下,您可以根据需要传递尽可能多的变量和任何类型

答案 1 :(得分:-1)

public function Download(Request $request) { $StartDate = Input::get('StartDate'); $EndDate = Input::get('EndDate'); $exporter = new UsersExport('StartDate','EndDate'); return $exporter->download('Summary Detail.xlsx'); }