我正在使用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>
答案 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'); }