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

php使用phpexcel开发库生成和读取excel

2014-12-31 00:34 627 查看

php使用phpexcel开发库生成和读取excel

excel的生成和读取在日常开发中用的很多,最基本的操作就是把数据库里的数据导出为excel或者读取excel的数据并插入到数据库,这两种需求是比较常见的。像java,C#可以使用POI开发库,php中也给我们提供了这样的第三方开发库phpexcel,这样php也能生成和读取excel了

1.先下载phpexcel第三方的开发库

2.新建一个项目并在根目录下面建一个lib文件夹,当然也可以是别的

3.把下载的phpexcel解压,把Classes文件夹下面的东西复制到新建的lib文件夹下面

4.使用这套开发库生成一个简单的excel

(1)首先引入要用到的php

[php]
view plaincopy





require_once 'lib/PHPExcel.php';
require_once 'lib/PHPExcel/Writer/Excel2007.php';
require_once 'lib/PHPExcel/Writer/Excel5.php';
require_once 'lib/PHPExcel/IOFactory.php';

(2)生成excel文档,我这里的数据直接写到了数组里,日常的开发也可能是从数据库读取出来
要理解phpexcel的使用最重要的是要理解清楚excel单元格的表示方法,例如B2表示第二行第二列的单元格,其他的以此类推,来看看生成excel的php代码

[php]
view plaincopy





<?php

/**
* PHPEXCEL生成excel文件
* @desc 支持任意行列数据生成excel文件,暂未添加单元格样式和对齐
*/

require_once 'lib/PHPExcel.php';
require_once 'lib/PHPExcel/Writer/Excel2007.php';
require_once 'lib/PHPExcel/Writer/Excel5.php';
require_once 'lib/PHPExcel/IOFactory.php';

$fileName = "test_excel";
$headArr = array("姓名","学号","成绩");
$data = array(array("蔡依林","2038010501","90"),array("潘玮柏","2038010502","91"),array("柳下惠","2038010503","80"));
getExcel($fileName,$headArr,$data);

function getExcel($fileName,$headArr,$data){
if(empty($data) || !is_array($data)){
die("data must be a array");
}
if(empty($fileName)){
exit;
}
$date = date("Y_m_d",time());
$fileName .= "_{$date}.xlsx";

//创建新的PHPExcel对象
$objPHPExcel = new PHPExcel();
$objProps = $objPHPExcel->getProperties();

//设置表头,从第二列开始
$key = ord("B");
foreach($headArr as $v){
$colum = chr($key);
$objPHPExcel->setActiveSheetIndex(0) ->setCellValue($colum.'1', $v);
$key += 1;
}

$column = 2;
$objActSheet = $objPHPExcel->getActiveSheet();
//遍历二维数组的数据
foreach($data as $key => $rows){
$span = ord("B");
// 列写入
foreach($rows as $keyName=>$value){
$j = chr($span);
//按照B2,C2,D2的顺序逐个写入单元格数据
$objActSheet->setCellValue($j.$column, $value);
//移动到当前行右边的单元格
$span++;
}
//移动到excel的下一行
$column++;
}

$fileName = iconv("utf-8", "gb2312", $fileName);
//重命名表
$objPHPExcel->getActiveSheet()->setTitle('Simple');
//设置活动单指数到第一个表,所以Excel打开这是第一个表
$objPHPExcel->setActiveSheetIndex(0);

$objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel2007');
//脚本方式运行,保存在当前目录
//$objWriter->save($fileName);

// 输出文档到页面
header('Content-Type: application/vnd.ms-excel');
header('Content-Disposition: attachment;filename="test.xls"');
header('Cache-Control: max-age=0');
$objWriter->save("php://output");
exit;

}

?>

生成的excel是下面这样样子



5.读取xls的内容

[php]
view plaincopy





<?php

/**
* PHPEXCEL生成excel文件
* @desc 支持任意行列数据生成excel文件,暂未添加单元格样式和对齐
*/
require_once 'lib/PHPExcel.php';
require_once 'lib/PHPExcel/Reader/Excel2007.php';
require_once 'lib/PHPExcel/Reader/Excel5.php';
include_once 'lib/PHPExcel/IOFactory.php';

$objReader = PHPExcel_IOFactory::createReader ( 'Excel2007' );
$objReader->setReadDataOnly ( true );
$objPHPExcel = $objReader->load ("test.xls");
//$objWorksheet = $objPHPExcel->getActiveSheet ();
$objWorksheet = $objPHPExcel->getSheet (0);
//取得excel的总行数
$highestRow = $objWorksheet->getHighestRow ();
//取得excel的总列数
$highestColumn = $objWorksheet->getHighestColumn ();
$highestColumnIndex = PHPExcel_Cell::columnIndexFromString ( $highestColumn );
$excelData = array ();
for($row = 2; $row <= $highestRow; $row++) {
for($col = 1; $col < $highestColumnIndex; $col++) {
$excelData[$row-2][] = $objWorksheet->getCellByColumnAndRow ( $col, $row )->getValue ();
}
}
echo "<pre>";
print_r($excelData);
echo "</pre>";

?>

这个数组打印出来是这个样子
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: