先引入类IOFactory.phpphp
require_once '../PHPExcel/IOFactory.php'; $filePath = "test.xlsx"; // 测试文件
加载测试文件segmentfault
下面主要判断Excel2007和Excel5类型,即xlsx/xlsm/xltx/xltm和xls/xlt格式文件ide
try { $inputFileType = PHPExcel_IOFactory::identify($filePath); if ($inputFileType !== "Excel5" && $inputFileType !== "Excel2007" ) { unlink($filePath) && str_alert(-1,"请确保导入的文件格式正确!"); } $objReader = PHPExcel_IOFactory::createReader($inputFileType); $objPHPExcel = $objReader->load($filePath); } catch(Exception $e) { unlink($filePath) && str_alert(-1,'加载文件发生错误:”'.pathinfo($filePath,PATHINFO_BASENAME).'”: '.$e->getMessage()); }
$sheet = $objPHPExcel->getSheet(0); //或者 $sheet = $objPHPExcel->getActiveSheet();
$highestRow = $sheet->getHighestRow(); $highestColumn = $sheet->getHighestColumn();
注意:有时候你会发现你的表格明明有内容的行数就5行,可是获取到的$highestRow却有7,8行或者更多,这多是由于你在操做你的表格的时候不当心点击了其它行数,虽然没有填写内容,但getHighestRow也是可以识别出行数;
想要获取有内容的行数应该使用getHighestDataRow和getHighestDataColumn
源码注释是这样介绍的string Highest row number that contains data,即包含数据的字符串最高行数.测试
xlsx类型的表格单元格是经过相似xy轴坐标来获取的,字体
可经过相似ui
$sheet->getCell("A1")->getValue(); $sheet->getCell("B2")->getValue();
获取相应位置的内容,
若是不想经过字母了来遍历获取,能够用数字索引方法code
$sheet->getCellByColumnAndRow(0,1); $sheet->getCellByColumnAndRow(1,2);
注意坐标中第一个参数从0开始,0表明A,1表明B...,第二个参数从1开始.
下面是遍历表格获取所有单元格内容:对象
$dataSet=array(); for ($column = "A"; $column <= $highestColumn; $column++) {//列数是以A列开始 for ($row = 4; $row <= $highestRow; $row++) { //行数是以第4行开始 $cell = $sheet->getCell($column . $row)->getValue(); if($cell instanceof PHPExcel_RichText) { //富文本转换字符串 $cell = $cell->__toString(); } $dataSet[$row][] = $cell; } }
其中富文本转换字符串,是使用$cell instanceof PHPExcel_RichText判断是否为富文本,查阅资料发现若是你的单元格中字符串包含两种以上的字体会自动被设为富文本,这时候须要__toString()转换索引
当咱们循环输出全部单元格后发现,一些被合并的单元格只有最左上坐标的是有内容的,其余都是null
例如A4,A5合并成一个单元格,getCell("A4")是有正常内容的,可是getCell("A5")是null.
isMergeRangeValueCell能够用来判断某个具体的单元格是否为最左上角字符串
$sheet->getCell('A' . $row)->isMergeRangeValueCell()
当$row为4的时候是返回true,5的时候返回false
获取表格中时间格式的内容,须要PHPExcel_Shared_Date::ExcelToPHP()来转换为php可识别的时间格式
date('Y-m-d',PHPExcel_Shared_Date::ExcelToPHP($sometime);