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>";
?>
这个数组打印出来是这个样子
相关文章推荐
- php使用phpexcel开发库生成和读取excel
- 使用PHPExcel生成和读取Excel文件
- php使用phpexcel生成excel包含图片并导出
- 使用PHPExcel生成和读取Excel文件
- 使用PHP Excel类读取和生成ex…
- PHP导出EXCEL快速开发指南--PHPEXCEL的使用详解,解决PHP下载文件名中文乱码
- PHP导出EXCEL快速开发指南--PHPEXCEL的使用详解
- 【PHP】PHP使用PHPExcel生成Excel表格文件(附带随机生成英文名函数)
- PHP导出EXCEL快速开发指南--PHPEXCEL的使用详解
- 使用PHPExcel生成和读取Excel文件
- 使用jxl工具包生成Excel以及读取Excel的方法
- 使用phpExcelReader读取excel文件 .
- PHP中使用ExcelReader读取EXCEL日期字段的处理
- 使用C#和Excel进行报表开发-生成统计图Chart
- 使用C#和Excel进行报表开发(三)-生成统计图(Chart)
- php读取excel文件-reader.php excel操作类使用
- PHP导出Excel php导入Excel PhpExcel使用说明 PhpExcel使用手册
- 使用C#和Excel进行报表开发(三)-生成统计图(Chart)
- 使用phpExcelReader读取excel文件
- 使用C#和Excel进行报表开发(三)-生成统计图(Chart)