1.8 KiB
		
	
	
	
	
	
	
	
			
		
		
	
	Creating a sheet from an array
Array
To create a new file from an array use ->fromArray($source, $nullValue, $startCell, $strictNullComparison, $headingGeneration) inside the sheet closure.
Excel::create('Filename', function($excel) {
    $excel->sheet('Sheetname', function($sheet) {
        $sheet->fromArray(array(
            array('data1', 'data2'),
            array('data3', 'data4')
        ));
    });
})->export('xls');
Alternatively you can use ->with().
$sheet->with(array(
    array('data1', 'data2'),
    array('data3', 'data4')
));
If you want to pass variables inside the closure, use use($data)
$data = array(
    array('data1', 'data2'),
    array('data3', 'data4')
);
Excel::create('Filename', function($excel) use($data) {
    $excel->sheet('Sheetname', function($sheet) use($data) {
        $sheet->fromArray($data);
    });
})->export('xls');
Null comparision
By default 0 is shown as an empty cell. If you want to change this behaviour, you can pass true as 4th parameter:
// Will show 0 as 0
$sheet->fromArray($data, null, 'A1', true);
To change the default behaviour, you can use
excel::export.sheets.strictNullComparisonconfig setting.
Eloquent model
It's also possible to pass an Eloquent model and export it by using ->fromModel($model). The method accepts the same parameters as fromArray
Auto heading generation
By default the export will use the keys of your array (or model attribute names) as first row (header column). To change this behaviour you can edit the default config setting (excel::export.generate_heading_by_indices) or pass false as 5th parameter:
// Won't auto generate heading columns
$sheet->fromArray($data, null, 'A1', false, false);
