有时录入数据很麻烦,但对每一个模型都写一个 Excel 解析类就很麻烦了,现在 tpadmin 提供了一键导入的功能,手动选择需要导入的列和列的对应关系,保证能将数据一次性最快的导入到数据库中
##方法
解析 Excel 头部,即第一行表头信息和列 (A、B、...、A1、...) 的对应关系
`Excel::parseHeader($file, $type = '')`
联合头部数据对应关系将数据解析到数据库中
`Excel::parse($file, $header, $perLimit, $insertFunc, $type = '')`
##参数
解析 Excel 头部 `parseHeader()`
| 名称 | 类型 | 说明 |
| --- | --- | --- |
| file | string | Excel 路径名文件名 |
| type | enum | Excel 版本类型,可选 Excel5 或 Excel2007,或为空自动识别 |
联合头部数据对应关系将数据解析到数据库中 `parse()`
| 名称 | 类型 | 说明 |
| --- | --- | --- |
| file | string | Excel 路径名文件名 |
| header | array | 表头对应字段信息 ['A'=>'field1', 'B'=>'field2', ...] |
| perLimit | int | 每次一次性写入数据库中的行数 |
| file | function | 写入数据库的回调函数,可以用匿名函数 |
| type | enum | Excel 版本类型,可选 Excel5 或 Excel2007,或为空自动识别 |
##使用示例
```
// 通过文件上传,然后取到上传后的完整路径文件名
$file = 'demo.xlsx';
// 解析 Excel 头部信息,返回 $excelHeader = ['A' => '第一行A列描述', 'B' => '第一行B列描述', 'C' => '第一行C列描述',...]
$excelHeader = Excel::parseHeader($file);
// 将 $excelHeader 数据抛给前端,让用户选择对应关系,然后再返回给后台进行对应数据的解析,例如抛给后台的数据如下
$header = ['A' => 'name', 'B' => 'sex', 'C' => 'age'];
$result = Excel::parse($file, $header, 20, function ($data) {
foreach ($data as &$v) {
$v['sex'] = $v['sex'] == '男' ? 1 : 0;
// 从 Excel 里直接解析出来的时间无法使用,需要进行转化,Excel::excelTime($date, $time=false) 可以将解析出的时间转为为标准时间格式 Y-m-d,如果 $time=true,则解析出来为 Y-m-d H:i:s 格式的时间,如果需要转化为时间戳再次使用 strototime 就 OK 了
$v['date'] = Excel::excelTime($v['date']);
}
Db::name('TableName')->insertAll($data);
});
```