PHP code example of dcat / easy-excel
1. Go to this page and download the library: Download dcat/easy-excel library . Choose the download type require .
2. Extract the ZIP file and open the index.php.
3. Add this code to the index.php.
<?php
require_once('vendor/autoload.php');
/* Start to develop here. Best regards https://php-download.com/ */
dcat / easy-excel example snippets
use Dcat\EasyExcel\Excel;
$array = [
['id' => 1, 'name' => 'Brakus', 'email' => '[email protected] ', 'created_at' => '...'],
...
];
$headings = ['id' => 'ID', 'name' => '名称', 'email' => '邮箱'];
// xlsx
Excel::export($array)->headings($headings)->download('users.xlsx');
// csv
Excel::export($array)->headings($headings)->download('users.csv');
// ods
Excel::export($array)->headings($headings)->download('users.ods');
use Dcat\EasyExcel\Excel;
use League\Flysystem\Adapter\Local;
use League\Flysystem\Filesystem;
$array = [...];
// 保存到当前服务器
Excel::export($array)->store('/tmp/users.xlsx');
// 使用 filesystem
$adapter = new Local(__DIR__);
$filesystem = new Filesystem($adapter);
Excel::export($array)->disk($filesystem)->store('users.xlsx');
use Dcat\EasyExcel\Excel;
$array = [...];
$xlsxContents = Excel::xlsx($array)->raw();
$csvContents = Excel::csv($array)->raw();
$odsContents = Excel::ods($array)->raw();
use Dcat\EasyExcel\Excel;
use League\Flysystem\Adapter\Local;
use League\Flysystem\Filesystem;
$headings = ['id', 'name', 'email'];
// 导入xlsx
$allSheets = Excel::import('/tmp/users.xlsx')->headings($headings)->toArray();
// 使用filesystem
$adapter = new Local(__DIR__);
$filesystem = new Filesystem($adapter);
$allSheets = Excel::import('users.xlsx')->disk($filesystem)->headings($headings)->toArray();
print_r($allSheets); // ['Sheet1' => [['id' => 1, 'name' => 'Brakus', 'email' => '[email protected] ', 'created_at' => '...']]]
use Dcat\EasyExcel\Excel;
use Dcat\EasyExcel\Contracts\Sheet as SheetInterface;
use Dcat\EasyExcel\Support\SheetCollection;
// 导入xlsx
Excel::import('/tmp/users.xlsx')->each(function (SheetInterface $sheet) {
// 获取表格名称,如果是csv文件,则此方法返回空字符串
$sheetName = $sheet->getName();
// 表格序号,从 0 开始
$sheetIndex = $sheet->getIndex();
// 是否是最后一次保存前打开的表格
$isActive = $sheet->isActive();
// 分块处理表格数据
$sheet->chunk(100, function (SheetCollection $collection) {
$chunkArray = $collection->toArray();
print_r($chunkArray); // [['id' => 1, 'name' => 'Brakus', 'email' => '[email protected] ', 'created_at' => '...']]
});
});
use Dcat\EasyExcel\Excel;
use Dcat\EasyExcel\Support\SheetCollection;
// 获取第一个表格内容
$firstSheet = Excel::import('/tmp/users.xlsx')->first()->toArray();
// 获取最后一次保存前打开的表格内容
$activeSheet = Excel::import('/tmp/users.xlsx')->active()->toArray();
// 获取指定名称或序号的表格内容
$sheet = Excel::import('/tmp/users.xlsx')->sheet('Sheet1')->toArray();
$sheet = Excel::import('/tmp/users.xlsx')->sheet(0)->toArray();
// 分块处理表格内容
Excel::import('/tmp/users.xlsx')
->first()
->chunk(1000, function (SheetCollection $collection) {
$collection = $collection->keyBy('id');
});