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代码

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是下面这样样子

php使用phpexcel开发库生成和读取excel_第1张图片


5.读取xls的内容

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 "
";
print_r($excelData);
echo "
"; ?>

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

php使用phpexcel开发库生成和读取excel_第2张图片

你可能感兴趣的:(excel,phpexcel)