时间:2021-05-26
本文实例讲述了PHPExcel实现的读取多工作表操作。分享给大家供大家参考,具体如下:
最近我们公司crm模块需要优化一下客户导入功能,之前的要求是:只需要从单个工作表中获取数据;现在的要求是:需要在多个工作表中获取对应数据,并导入数据库;
幸亏PHPExcel已经给我们提供了获取多个sheet工作表的方法。下面直接上代码:【这里我用的是tp3.2.3】
/** * 导入excel文件 * @param string $file excel文件路径 * @return array excel文件内容数组 */function import_excel($file){ // 判断文件是什么格式 $type = pathinfo($file); $type = strtolower($type["extension"]); if ($type=='xlsx') { $type='Excel2007'; }elseif($type=='xls') { $type = 'Excel5'; } ini_set('max_execution_time', '0'); Vendor('PHPExcel.PHPExcel'); $objReader = PHPExcel_IOFactory::createReader($type);//判断使用哪种格式 $objReader ->setReadDataOnly(true); //只读取数据,会智能忽略所有空白行,这点很重要!!! $objPHPExcel = $objReader->load($file); //加载Excel文件 $sheetCount = $objPHPExcel->getSheetCount();//获取sheet工作表总个数 $rowData = array(); $RowNum = 0; for($i =0;$i <= $sheetCount-1;$i++){//循环sheet工作表的总个数 $sheet = $objPHPExcel->getSheet($i); $highestRow = $sheet->getHighestRow(); $RowNum += $highestRow-1;//计算所有sheet的总行数 $highestColumn = $sheet->getHighestColumn(); //从第$i个sheet的第1行开始获取数据 for($row = 1;$row <= $highestRow;$row++){ //把每个sheet作为一个新的数组元素 键名以sheet的索引命名 利于后期数组的提取 $rowData[$i][] = arrToOne($sheet->rangeToArray('A' . $row . ':' . $highestColumn . $row, NULL, TRUE, FALSE)); } } foreach($rowData as $k=>$v){ array_shift($rowData[$k]); } echo '<pre>'; print_r($rowData);//打印结果 echo '</pre>'; return array("RowNum" => $RowNum,"Excel_Data" => $rowData);}Excel截图如下:
打印结果如下:0对应第一个sheet;以此类推第3个就是最后一个sheet;
注意:当某一个sheet不存在任何数据时,我这里会创建该元素为空数组,比如下面结果的第3个元素 ;所以在插入数据库操作的时候需要再判断一下是否为空!
<pre>Array
(
[0] => Array
(
[0] => Array
(
[0] => 测试数据001
[1] =>
[2] => 联系人1
[3] => 女
[4] =>
[5] =>
[6] =>
[7] =>
[8] =>
[9] =>
[10] =>
[11] =>
[12] =>
)
[1] => Array
(
[0] => 测试数据002
[1] =>
[2] => 联系人2
[3] => 女
[4] =>
[5] =>
[6] =>
[7] =>
[8] =>
[9] =>
[10] =>
[11] =>
[12] =>
)
)
[1] => Array
(
[0] => Array
(
[0] => 测试数据014
[1] =>
[2] => 联系人13
[3] => 女
[4] =>
[5] =>
[6] =>
[7] =>
[8] =>
[9] =>
[10] =>
[11] =>
[12] =>
)
)
[2] => Array
(
[0] => Array
(
[0] => 测试数据015
[1] =>
[2] => 联系人13
[3] => 女
[4] =>
[5] =>
[6] =>
[7] =>
[8] =>
[9] =>
[10] =>
[11] =>
[12] =>
)
)
[3] => Array
(
)
)
</pre>
至此, 以上就成功获取到了每一个sheet的数据;
PS:关于PHPExcel文件可至此下载 https://www.jb51.net/codes/194070.html。
更多关于PHP相关内容感兴趣的读者可查看本站专题:《php操作office文档技巧总结(包括word,excel,access,ppt)》、《PHP数组(Array)操作技巧大全》、《PHP数据结构与算法教程》、《php程序设计算法总结》、《PHP数学运算技巧总结》、《php正则表达式用法总结》、《php字符串(string)用法总结》及《php常见数据库操作技巧汇总》
希望本文所述对大家PHP程序设计有所帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了thinkPHP+PHPExcel实现读取文件日期的方法。分享给大家供大家参考,具体如下:我们使用PHPExcel读取excel文件后发现,时间都
下载phpexcel文件,地址:phpexcel.codeplex.com/代码示例require_once'phpexcel/Classes/PHPExcel
本文实例讲述了PHPExcel冻结(锁定)表头的简单实现方法。分享给大家供大家参考,具体如下:PHPExcel是一款功能比较强大的操作微软excel的PHP插件
作为一个原本的Java党,用过PHP才知道,原来对于Excel文件的写入和读取原来可以这么简单!利用PHP实现对于Excel的读取,主要借助于PHPExcel插
phpExcel将读取的单元格信息保存在内存中,我们可以通过复制代码代码如下:PHPExcel_Settings::setCacheStorageMethod(