使用PhpOffice\PhpSpreadsheet读取excel数据
浏览:2182 时间:2019-10-13 15:32:34
PhpOffice\PhpSpreadsheet是一个PHP类库,用来帮助我们简单、高效实现从Excel读取Excel的数据和导出数据到Excel。也是我们日常开发中,经常会遇到的使用场景。
1、可通过composer安装:
composer require phpoffice/phpspreadsheet
下面是封装的类方法,有具体的说明
<?php
/**
* 使用的是thinkphp框架
* 引用PhpOffice\PhpSpreadsheet类库
* 其实就是引入IOFactory.php文件
*/
use PhpOffice\PhpSpreadsheet\IOFactory;
/**
* excel
*/
class ExcelHelper
{
/**
* 读取excel文件的数据
* $row:获取第几行开始的数据
* $file_path:excel文件的路径(最好绝对路径)
* index_arr:要读取的列;如 [0,1,2,3]
* $fields:读取的列对应的自定义变量名;如 ['id','name','sex','age']
* extra :可以为空
*/
public function get_excel_data($row, $file_path, $fields = [], $index_arr = [], $extra = [])
{
$objPHPExcel = IOFactory::load($file_path);
$data = $objPHPExcel->getSheet(0)->toArray();
$count = count($data);
$insert_batch = array();
for ($i = $row; $i < $count; $i++) {
$insert = array();
for($j = 0; $j < count($fields); $j ++) {
$insert += array($fields[$j] => $data[$i][$index_arr[$j]]);
}
$insert += $extra;
array_push($insert_batch, $insert);
}
return $insert_batch;
}
/**
* 读取excel文件的某一行的数据
* $row:第几行,从0开始
* $file_path:excel文件的路径(最好绝对路径)
* index_arr:要读取的列;如 [0,1,2,3]
* $fields:读取的列对应的自定义变量名;如 ['id','name','sex','age']
* extra :可以为空
*/
public function given_excel_data($row, $file_path, $fields = [], $index_arr = [], $extra = [])
{
$objPHPExcel = IOFactory::load($file_path);
$data = $objPHPExcel->getSheet(0)->toArray();
$count = $row+1;
$insert_batch = array();
for ($i = $row; $i < $count; $i++) {
$insert = array();
for($j = 0; $j < count($fields); $j ++) {
$insert += array($fields[$j] => $data[$i][$index_arr[$j]]);
}
$insert += $extra;
if (!empty($insert)){
array_push($insert_batch, $insert);
}
}
return $insert_batch;
}
/**
* 读取excel文件所有数据
* $file_path:excel文件的路径(最好绝对路径)
*/
public function get_excel_all_data($file_path){
$objPHPExcel = IOFactory::load($file_path);
$data = $objPHPExcel->getSheet(0)->toArray();
return $data;
}
}
excel表结构分析:
封装参数中的index_arr=[0,1,2,3,4,5]代表获取了6列数据
封装参数中的$row代表行数 从0开始