栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > PHP > php开源框架 > tpAdmin

Excel一键导入 - tpAdmin 文档

tpAdmin 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Excel一键导入 - tpAdmin 文档


有时录入数据很麻烦,但对每一个模型都写一个 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);
});
```

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/214043.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号