背景
在使用PHP解析Excel数据的时候,经常期望能把Excel中的数据自动和数据库字段建立上映射关系;
比如下图一 - Excel文件,图二 - 数据库字段
如果读取Excel后直接返回下面的数据就好了!
虽然这是在处理excel的时常用的需求,但是目前在网上没有找到一个方便好用的方法!
于是我决定造了一个轮子,我封装了一个比较简单的方式,基本只要一行代码,就可以直接返回下面结构;
[{
"name": "张三",
"height": 180,
"birthday": "2000年11月13日"
}, {
"name": "李四",
"height": 160,
"birthday": "2001年12月3日"
}, {
"name": "王五",
"height": 170,
"birthday": "1992年1月13日"
}]
安装
安装扩展包
composer require jsyqw/utils
/**
$file: excel 文件路径
数据库字段 birthday 和excel表头中的数据 "出生日期" 对应,
数据库字段 name 和excel表头中的数据 "名称" 对应,
数据库字段 height 和excel表头中的数据 "身高" 对应,
*/
// 敲重点,这个就是那个简化封装的代码
$data = ExcelHelper::instance()->getData($file, ["birthday" => "出生日期", "name" => "名称", "height" => "身高"]);
$data 的数据如下:
[{
"B": "男",
"C": "打篮球",
"E": 70,
"G": null,
"name": "张三",
"height": 180,
"birthday": "2000年11月13日"
}, {
"B": "女",
"C": null,
"E": 50,
"G": null,
"name": "李四",
"height": 160,
"birthday": "2001年12月3日"
}, {
"B": "女",
"C": "画画",
"E": 40,
"G": null,
"name": "王五",
"height": 170,
"birthday": "1992年1月13日"
}]
对应的源码地址:
https://github.com/jasonyqwang/Utils.git