程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> PHP 導出Excel

PHP 導出Excel

編輯:關於PHP編程

PHP 導出Excel


在開發一個商城網站的時候,客戶需要一個導出報表的功能,我使用PHPExcel來實現這個功能。

下載PHPExcel_1.8.0_doc.zip,將解壓後的文件夾裡的Classes上傳到網站的根目錄下,Classes目錄內的內容如下:

\

導出文件Excel.php

require_once dirname(__FILE__).'/Classes/PHPExcel.php';//引入PHPExcel
.....此處略去從數據庫獲取數據的過程,$a為需要導出的數組......
$numArr = array('A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P','Q','R','S','T','U','V','W','X','Y','Z','AA','AB','AC','AD','AE','AF','AG','AH','AI','AJ','AK','AL','AM','AN','AO','AP','AQ','AR','AS','AT','AU','AV','AW','AX','AY','AZ');
// Create new PHPExcel object
$objPHPExcel = new PHPExcel();

$arr = array('訂單號','下單時間','城市','地區', '客戶名稱', '收貨人', '聯系電話', '收貨地址', 'ERP客戶名稱', '物流系統客戶名稱', '活動項目',
 '品牌', '型號', '顏色', '物流系統型號', '訂貨量', '單價', '代收貨款', '紅包', '價保返利', '運費', '實收金額', '付款方式', '訂單來源',
 '上游廠商', '是否在倉', '快遞面單號', '訂單狀態', '確認時間', '末次狀態確認時間', '描述', '對應業務', '對應客服', '商家留言', '下單摘要',
 '業務員', '聯系方式');
// 輸出標題
echo date('H:i:s') , " Add some data" , EOL;
//設置換行
$objPHPExcel->getActiveSheet()->getStyle('H')->getAlignment()->setWrapText(true);
$objPHPExcel->getActiveSheet()->getStyle('Y')->getAlignment()->setWrapText(true);
//設置相應列的寬度
$objPHPExcel->setActiveSheetIndex(0)->getColumnDimension('A')->setWidth(15);
$objPHPExcel->setActiveSheetIndex(0)->getColumnDimension('B')->setWidth(20);
$objPHPExcel->setActiveSheetIndex(0)->getColumnDimension('G')->setWidth(15);
$objPHPExcel->setActiveSheetIndex(0)->getColumnDimension('H')->setWidth(40);
$objPHPExcel->setActiveSheetIndex(0)->getColumnDimension('I')->setWidth(15);
$objPHPExcel->setActiveSheetIndex(0)->getColumnDimension('J')->setWidth(15);
//輸出第一行
$objPHPExcel->setActiveSheetIndex(0)
	    ->setCellValue('A1', $arr[0])
            ->setCellValue('B1', $arr[1])
            ->setCellValue('C1', $arr[2])
            ->setCellValue('D1', $arr[3])
            ->setCellValue('E1', $arr[4])
            ->setCellValue('F1', $arr[5])
            ->setCellValue('G1', $arr[6])
            ->setCellValue('H1', $arr[7])
            ->setCellValue('I1', $arr[8])
            ->setCellValue('J1', $arr[9])
	    ->setCellValue('K1', $arr[10])
	    ->setCellValue('L1', $arr[11]);


//輸出內容
for($i=0;$isetActiveSheetIndex(0)
		->setCellValue($numArr[0].($i+2), $a[$i]['order_sn'])
		->setCellValue($numArr[1].($i+2), $a[$i]['add_time'])
		->setCellValue($numArr[2].($i+2), $a[$i]['city'])
		->setCellValue($numArr[3].($i+2), $a[$i]['region_name'])
		->setCellValue($numArr[4].($i+2), $a[$i]['company'])
		->setCellValue($numArr[5].($i+2), $a[$i]['consignee'])
		->setCellValue($numArr[6].($i+2), $a[$i]['mobile'])
		->setCellValue($numArr[7].($i+2), $a[$i]['address'])
		->setCellValue($numArr[8].($i+2), '')
		->setCellValue($numArr[9].($i+2), '')
		->setCellValue($numArr[10].($i+2), '')
		->setCellValue($numArr[11].($i+2), $a[$i]['brand_name']);
}

// Rename worksheet
echo date('H:i:s') , " Rename worksheet" , EOL;
$dirName = date("Ymd");//目錄名
$fileName = date("YmdHis");//文件名
$objPHPExcel->getActiveSheet()->setTitle($fileName);


// Set active sheet index to the first sheet, so Excel opens this as the first sheet
$objPHPExcel->setActiveSheetIndex(0);


// Save Excel 2007 file
echo date('H:i:s') , " Write to Excel2007 format" , EOL;
$callStartTime = microtime(true);
if(!opendir('../excel/'.$dirName)){
	mkdir('../excel/'.$dirName);
}
$objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel2007');
$objWriter->save('../excel/'.$dirName.'/'.$fileName.'.xlsx');

$end = getCurrentTime();
$spend = $end-$begin;
if ($spend > 30){
	echo '<script>if(confirm("執行超時!")){ window.history.back(-1);}</script>';
	exit;
}
header('Location:http://'.$_SERVER['HTTP_HOST'].'/excel/'.$dirName.'/'.$fileName.'.xlsx');


  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved