如何在Yii Framework中使用PHPExcel組件【備忘】

PHPExcel下載地址http://www.yiiframework.com/extension/phpexcel

將下載的PHPExcel壓縮包解壓到Yii Framework目錄framework\vendors下

代碼如下

 

/**
* 將數據導出到Excel
*/
public function actionExport()
{
//取要導出到Excel的數據
$criteria = $this->_getCriteria();
$data = Statistics::model()->findAll($criteria);

// 獲取PHPExcel引用路徑
$phpExcelPath = Yii::getPathOfAlias('system.vendors');

// 關閉YII的自動加載功能,改用手動加載,否則會出錯,PHPExcel有自己的自動加載功能
// YII框架對於組件的自動加載,要求類名與文件名一致;
// 而PHPExcel類對應的文件名包含了上級目錄名稱,如:IOFactory類對應的文件名爲PHPExcel_IOFactory.php

spl_autoload_unregister(array('YiiBase','autoload'));
include($phpExcelPath . DIRECTORY_SEPARATOR . 'PHPExcel.php');

//下面是Excel數據導出處理邏輯
$objPHPExcel = PHPExcel_IOFactory::load('./content/template/report.xlsx');

$objPHPExcel->getProperties()->setCreator("Kalman")
->setTitle("統計報表")
->setSubject("統計報表")
->setDescription("統計報表");


$objPHPExcel->setActiveSheetIndex(0)
->setCellValue('A1', 'Hello')
->setCellValue('B2', 'world!')
->setCellValue('C1', 'Hello')
->setCellValue('D2', 'world!');

$objPHPExcel->setActiveSheetIndex(0)
->setCellValue('A25', '123456');

$objPHPExcel->getActiveSheet()->setTitle('report');

// Excel打開後顯示的工作表
$objPHPExcel->setActiveSheetIndex(0);

//通瀏覽器輸出Excel報表
header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');
header('Content-Disposition: attachment;filename="report.xlsx"');
header('Cache-Control: max-age=0');

$objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel2007');
$objWriter->save('php://output');
Yii
::app()->end();

//恢復Yii自動加載功能
spl_autoload_register(array('YiiBase','autoload'));
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章