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

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

/**
 * 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

/**
 * 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>";

?>

这个数组打印出来是这个样子


  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值