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');
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.
It's also possible to pass an Eloquent model and export it by using ->fromModel($model). The method accepts the same parameters as fromArray
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);