xls可以用任何版本的excel軟體打開,xlsx隻能用2007以上的版本。這裡用了phpexcel庫。
<?php
date_default_timezone_set("Etc/GMT-8"). //設定時區
header('Content-Type: text/html; charset=utf-8'); //設定網頁編碼方式,最好是utf-8
require_once './Classes/PHPExcel.php'; //路徑根據自己實際項目的路徑進行設定
$objPHPExcel = new PHPExcel(); //建立PHPExcel執行個體
//下面是對mysql資料庫的連接配接
$conn = mysql_connect("192.168.1.10","root","roonen") or die("資料庫連接配接失敗!");
mysql_select_db("zyxv2",$conn); //連接配接資料庫
mysql_query("set names 'GBK'"); //轉換字元編碼
$sql = mysql_query("select * from goods_info"); //查詢sql語句
/*--------------設定表頭資訊------------------*/
$objPHPExcel->setActiveSheetIndex(0)
->setCellValue('A1', 'ID編号')
->setCellValue('B1', '商品名稱')
->setCellValue('C1', '貨号')
->setCellValue('D1', '商品條形碼')
->setCellValue('E1', '型号規格')
->setCellValue('F1', '吊牌價');
/*--------------開始從資料庫提取資訊插入Excel表中------------------*/
$i=2; //定義一個i變量,目的是在循環輸出資料是控制行數
//$rows=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');
while($rs=mysql_fetch_array($sql)){
$rm = iconv("gbk", "UTF-8//IGNORE",$rs[1]); //對字元進行編碼将資料庫裡GB2312的中文字元轉換成UTF-8格式
$objPHPExcel->setActiveSheetIndex(0)
->setCellValue("A".$i, $rs[0]) //向單元格中填寫資料
->setCellValue("B".$i, $rm) //由于我的這一列是中文,是以在上面進行了編碼
->setCellValue("C".$i, $rs[2])
->setCellValue("D".$i, $rs[3])
->setCellValue("E".$i, $rs[4])
->setCellValue("F".$i, $rs[5]);
$i++;
}
/*--------------下面是設定其他資訊------------------*/
$objPHPExcel->getActiveSheet()->setTitle('Example1'); //設定sheet的名稱
$objPHPExcel->setActiveSheetIndex(0); //設定sheet的起始位置
//注意下面是excel2007。不要寫成excel5不然會是亂碼。
//如果還是亂碼看看你自己資料的編碼方式
$objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel2007'); //通過PHPExcel_IOFactory的寫函數将上面資料
// $objWriter->save('php://output'); //到浏覽器
//$objWriter->save(str_replace('.php', date('Y-m-d H-i-s').'.xls', __FILE__));
$outputFileName = "測試.xls";
header("Content-Type: application/force-download");//标頭您的浏覽器并告訴它下載下傳,而不是在浏覽器中運作的檔案
header("Content-Type: application/octet-stream");//檔案流
header("Content-Type: application/download"); //下載下傳檔案
header('Content-Disposition:attachment;filename=" $outputFileName'); //到檔案
header("Content-Transfer-Encoding: binary");
header("Expires: Mon, 26 Jul 1997 05:00:00 GMT");
header("Last-Modified: " . gmdate("D, d M Y H:i:s") . " GMT");//上一次修改時間
header("Cache-Control: must-revalidate, post-check=0, pre-check=0");
header("Pragma: no-cache"); //不緩存頁面
$objWriter->save('php://output');
?>