php操作excel文件 基于phpexcel

2015-01-24信息快讯网

最近在工作中需要处理多语言的翻译问题,翻译都是写在excel表格里面。为了处理方便我就保留中文和英文两列。这样需要将这些数据从excel中取出来,然乎保存在excel的数组中,通过使用循环数组将相应的数据放入到数据库中。

所以工作的第一步就是要将数据从excel中取出来。这里我使用到了一个开源php处理excel类:phpexcel. 该项目的详细信息 http://phpexcel.codeplex.com/ 。
我目前使用的是phpexcel1.7.3版本, 解压缩后里面有一个PHPExcel和PHPExcel.php文件。
我们主要使用那个PHP文件。见下图文件目录结构
php操作excel文件 基于phpexcel_信息快讯网

这个版本据说是可以支持excel2007,但是我使用2007编辑的xlsx是无法获得该库的支持。于是乎我就将它转化为2003。感觉支持地很好。
下面介绍一下具体的使用:
 
require_once('./phpexcel1.7.3/PHPExcel.php'); 
$php_excel_obj = new PHPExcel(); 
$php_reader = newPHPExcel_Reader_Excel2007(); 

if(!$php_reader->canRead($file_name)) 
{ 
$php_reader= new PHPExcel_Reader_Excel5(); 
if(!$php_reader->canRead($file_name)) 
{ 
echo'NO Excel!'; 
} 
} 
$php_excel_obj = $php_reader->load($file_name); 
$current_sheet =$php_excel_obj->getSheet(0); 

上面的主要功能是初始化相关的excel类,并装载excel第一个sheet

$all_column =$current_sheet->getHighestColumn();
$all_row =$current_sheet->getHighestRow();

以上分别获得该表格的最大列值(字母表示如:‘G'),和最大的行数(数值表示)

下面将使用循环来讲excel里面的数据读到excel中:
 
$all_arr = array(); 
$c_arr = array(); 

//字符对照表 
for($r_i = 1; $r_i<=$all_row; $r_i++) 
{ 
$c_arr= array(); 
for($c_i= 'A'; $c_i<= 'B'; $c_i++) 
{ 
$adr= $c_i . $r_i; 

$value= $current_sheet->getCell($adr)->getValue(); 

if($c_i== 'A' && empty($value) ) 
break; 
if(is_object($value)) 
$value= $value->__toString(); 
$c_arr[$c_i]= $value; 
} 

$c_arr&& $all_arr[] = $c_arr; 
} 



下面简单地介绍一下phpexcel的写操作,这个操作经常用于将数据库中的数据导入到excel中,便于展示和做成更美观的效果。
 
require_once('./phpexcel1.7.3/PHPExcel.php'); 

$excel_obj = new PHPExcel(); 
$objWriter = newPHPExcel_Writer_Excel5($excel_obj); 
$excel_obj->setActiveSheetIndex(0); 
$act_sheet_obj=$excel_obj->getActiveSheet(); 

$act_sheet_obj->setTitle('sheet'); 
$act_sheet_obj->setCellValue('A1', '字符串内容'); 
$act_sheet_obj->setCellValue('A2', 26); 

$file_name = "output.xls"; 
$objWriter->save($file_name); 

代码很简单, 首先初始化相关的excel写类,然后写入数据,最后保存为xls文件。
输出的效果见图
php操作excel文件 基于phpexcel_信息快讯网
DISCUZ在win2003环境下 Unable to access ./include/common.inc.php in... 的问题终极解决方案
php数组函数序列之array_slice() - 在数组中根据条件取出一段值,并返回
php数组函数序列之array_splice() - 在数组任意位置插入元素
php数组函数序列之next() - 移动数组内部指针到下一个元素的位置,并返回该元素值
php数组函数序列之array_key_exists() - 查找数组键名是否存在
PHP中的strtr函数使用介绍(str_replace)
PHP下利用shell后台运行PHP脚本,并获取该脚本的Process ID的代码
PHP 命令行工具 shell_exec, exec, passthru, system详细使用介绍
php正则表达式(regar expression)
php程序的国际化实现方法(利用gettext)
ThinkPHP与PHPExcel冲突解决方法
PHP导出MySQL数据到Excel文件(fputcsv)
php编程实现获取excel文档内容的代码实例
PHP导入Excel到MySQL的方法
PHP生成excel时单元格内换行问题的解决方法
用PHP为SHOPEX增加日志功能代码
PHP 多维数组排序(usort,uasort)
PHP extract 将数组拆分成多个变量的函数
PHP+ACCESS 文章管理程序代码
PHP similar_text 字符串的相似性比较函数
php 提速工具eAccelerator 配置参数详解
php access 数据连接与读取保存编辑数据的实现代码
AMFPHP php远程调用(RPC, Remote Procedure Call)工具 快速入门教程
php file_exists 检查文件或目录是否存在的函数
php disk_free_space 返回目录可用空间
php将数据库导出成excel的方法
在Windows下编译适用于PHP 5.2.12及5.2.13的eAccelerator.dll(附下载)
在PHP中操作Excel实例代码
两个开源的Php输出Excel文件类
Linux下将excel数据导入到mssql数据库中的方法
php 操作excel文件的方法小结
©2014-2024 dbsqp.com