您的位置:首页 > 编程语言 > PHP开发

Thinkphp 3.2命名空间版如何使用PHPExcel导入Excel文件

2015-08-08 16:18 676 查看
如题,使用过程中遇到的问题,现在来记录一下。

前文讲过如何导出为excel文件,现在重点说一下,如何导入excel文件。

先上代码。

//导入PHPExcel类库
import("Common.Org.PHPExcel");
import("Common.Org.PHPExcel.Reader.Excel5");
import("Common.Org.PHPExcel.IOFactory.php");
$objReader = \PHPExcel_IOFactory::createReader('Excel5'); //使用excel2007 版的格式来格式化excel数据
ini_set('memory_limit', '1024M');
ini_set('max_execution_time','10000');
$filename = 'a.xls';
$objPHPExcel = $objReader->load($filename);
$sheet = $objPHPExcel->getSheet(0);
$highestRow = $sheet->getHighestRow(); // 取得总行数
$highestColumn = $sheet->getHighestColumn(); // 取得总列数
$k = 0;

//循环读取excel文件,读取一条,插入一条
//j表示从哪一行开始读取
//$a表示列号
for($j=2;$j<=$highestRow;$j++)
{
$a = $objPHPExcel->getActiveSheet()->getCell("A".$j)->getValue();//获取A列的值
$b = $objPHPExcel->getActiveSheet()->getCell("B".$j)->getValue();//获取B列的值
$c = $objPHPExcel->getActiveSheet()->getCell("C".$j)->getValue();//获取C列的值

$info = array(
'number' => $a,
'shibiema' => $b,
'haopai' => $c,
);
//print_r($sql);exit;


导入和导出主要的区别是 $bojPHPExcel获取的方法不一样。

另外注意本文中有两处 init_set , 第一个1024M 是讲内容使用限制,如果你导入的文件比较大,那你就要把这这个加上,否则会报类似下面的错误。

Allowed memory size of 134217728 bytes exhausted

另一个是超时时间,单位是秒。同样,如果导入的文件太多,也会报错,一般会报下面的错误

Maximum execution time of 30 seconds exceeded

循环的时候,已经取得了数据,至于你要版处理这些数据那就是你的事情了!!!

导出见上文:http://blog.csdn.net/hotlinhao/article/details/47358593

PHPExcel 文件
http://download.csdn.net/detail/hotlinhao/8977351
请将下载的文件放到/Application/Common/Org/  文件夹下
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  Thinkphp phpExcel