下載PHPExcel_1.8.0_doc.zip http://phpexcel.codeplex.com/,將解壓後的文件夾裡的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;$i<count($a);$i++){ $objPHPExcel->setActiveSheetIndex(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');
簡單點就發送EXCEL頭給浏覽器
header("Content-type:application/vnd.ms-excel");
header("Content-Disposition:filename=aa.xls");
復雜的三言兩語將不清
你可以使用phpexcel來進行輸出 很好用官方地址: phpexcel.codeplex.com/ 右上角有 download使用方法:<? //設置PHPExcel類庫的include path set_include_path('.'. PATH_SEPARATOR . 'D:\Zeal\PHP_LIBS' . PATH_SEPARATOR . get_include_path()); /** * 以下是使用示例,對於以 //// 開頭的行是不同的可選方式,請根據實際需要 * 打開對應行的注釋。 * 如果使用 Excel5 ,輸出的內容應該是GBK編碼。 */ require_once 'PHPExcel.php'; // uncomment ////require_once 'PHPExcel/Writer/Excel5.php'; // 用於其他低版本xls // or ////require_once 'PHPExcel/Writer/Excel2007.php'; // 用於 excel-2007 格式 // 創建一個處理對象實例 $objExcel = new PHPExcel(); // 創建文件格式寫入對象實例, uncomment ////$objWriter = new PHPExcel_Writer_Excel5($objExcel); // 用於其他版本格式 // or ////$objWriter = new PHPExcel_Writer_Excel2007($objExcel); // 用於 2007 格式 //$objWriter->setOffice2003Compatibility(true); //************************************* //設置文檔基本屬性 $objProps = $objExcel->getProperties(); $objProps->setCreator("Zeal Li"); $objProps->setLastModifiedBy("Zeal Li"); $objProps->setTitle("Office XLS Test Document"); $objProps->setSubject(&q......余下全文>>