十方地藏 2016-04-20
最近在做一个php读取excel存入数据库的功能,于是用到了phpexcel,下载安装以后只能读取excel2003,2007以后的读取不了,搜了很多很多方法,也用了不少时间,最后总结一下吧,希望帮助以后像我这样的新手
首先读取2007的时候 一直没法load文件,最后发现好像是,没有读取权限吧?
说说解决方法吧
这时又报错了:PHPExcel 报 Allowed memory size of 8388608 byte
<!--more-->解决方法:
使用 phpExcel 报 Allowed memory size of 8388608 bytes exhausted 错误,原因是php页面消耗的最大内存默认是为 8M (在PHP的ini件里可以看到) ,如果文件太大 或图片太大 在读取的时候 会发生上述错误。
解决办法:
1,修改 php.ini将memory_limit由 8M 改成 16M(或更大),重启apache服务
2,在PHP 文件中 加入 ini_set('memory_limit','100M'); //100不行就写10000 测试一下
注意:为了系统的其它资源的正常使用 请您不要将 memory_limit设置太大,其中-1为不限
3,修改.htaccess 文档(前提是该目录支持.htaccess)在文档中新增一句:php_value memory_limit 16M(或更大)
下面是一个测试页面:
<?php ini_set('memory_limit','200M'); //设置文件上传大小 require_once 'Classes/PHPExcel/IOFactory.php'; $reader = PHPExcel_IOFactory::createReader('Excel2007'); // 读取 excel 文件方式 此方法是读取excel2007之前的版本 excel2007 为读取2007以后的版本 也可以查\Classes\PHPExcel\Reader 文件夹中的类(为所有读取类,需要哪个填上哪个就行) $resource = 'test.xlsx'; if (!file_exists($resource)) { exit("$resource is not exists.\n"); } $PHPExcel = $reader->load("test.xlsx"); // 文件名称 $sheet = $PHPExcel->getSheet(0); // 读取第一个工作表从0读起 $highestRow = $sheet->getHighestRow(); // 取得总行数 $highestColumn = $sheet->getHighestColumn(); // 取得总列数 echo $highestRow.$highestColumn; // 根据自己的数据表的大小修改 $arr = array(1=>'A',2=>'B',3=>'C',4=>'D',5=>'E',6=>'F'); // 每次读取一行,再在行中循环每列的数值 for ($row = 1; $row <= $highestRow; $row++) { for ($column = 0; $column < 6; $column++) { $val = $sheet->getCellByColumnAndRow($column, $row)->getValue(); $list[$row][] = $val; } } echo "<pre>".print_r($list)."</pre>"; ?>