侧边栏壁纸
博主头像
落叶人生博主等级

走进秋风,寻找秋天的落叶

  • 累计撰写 130562 篇文章
  • 累计创建 28 个标签
  • 累计收到 9 条评论
标签搜索

目 录CONTENT

文章目录

PHPExcel 读取导入 excel2003,2007各个版本整理

2024-05-15 星期三 / 0 评论 / 0 点赞 / 102 阅读 / 2746 字

最近在做一个php读取excel存入数据库的功能,于是用到了phpexcel,下载安装以后只能读取excel2003,2007以后的读取不了,搜了很多很多方法,也用了不少时间,最后总结一下吧,希望帮助

最近在做一个php读取excel存入数据库的功能,于是用到了phpexcel,下载安装以后只能读取excel2003,2007以后的读取不了,搜了很多很多方法,也用了不少时间,最后总结一下吧,希望帮助以后像我这样的新手

首先读取2007的时候 一直没法load文件,最后发现好像是,没有读取权限吧?

说说解决方法吧

  1. 设置php.ini里面的open_basedir,把前面的;去掉,也就是取消注释

这时又报错了:PHPExcel 报 Allowed memory size of 8388608 byte

解决方法:

使用 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>";?>

转载自:http://www.9958.pw/post/phpexcel_2003_2007

广告 广告

评论区