国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發(fā) > PHP > 正文

PHP導(dǎo)出MySQL數(shù)據(jù)到Excel文件(fputcsv)

2024-05-04 23:18:00
字體:
供稿:網(wǎng)友
這里的方法是利用fputcsv寫CSV文件的方法,直接向?yàn)g覽器輸出Excel文件。

復(fù)制代碼 代碼如下:


// 輸出Excel文件頭,可把user.csv換成你要的文件名
header('Content-Type: application/vnd.ms-excel');
header('Content-Disposition: attachment;filename="user.csv"');
header('Cache-Control: max-age=0');

// 從數(shù)據(jù)庫中獲取數(shù)據(jù),為了節(jié)省內(nèi)存,不要把數(shù)據(jù)一次性讀到內(nèi)存,從句柄中一行一行讀即可
$sql = 'select * from tbl where ……';
$stmt = $db->query($sql);

// 打開PHP文件句柄,php://output 表示直接輸出到瀏覽器
$fp = fopen('php://output', 'a');

// 輸出Excel列名信息
$head = array('姓名', '性別', '年齡', 'Email', '電話', '……');
foreach ($head as $i => $v) {
// CSV的Excel支持GBK編碼,一定要轉(zhuǎn)換,否則亂碼
$head[$i] = iconv('utf-8', 'gbk', $v);
}

// 將數(shù)據(jù)通過fputcsv寫到文件句柄
fputcsv($fp, $head);

// 計數(shù)器
$cnt = 0;
// 每隔$limit行,刷新一下輸出buffer,不要太大,也不要太小
$limit = 100000;

// 逐行取出數(shù)據(jù),不浪費(fèi)內(nèi)存
while ($row = $stmt->fetch(Zend_Db::FETCH_NUM)) {

$cnt ++;
if ($limit == $cnt) { //刷新一下輸出buffer,防止由于數(shù)據(jù)過多造成問題
ob_flush();
flush();
$cnt = 0;
}

foreach ($row as $i => $v) {
$row[$i] = iconv('utf-8', 'gbk', $v);
}
fputcsv($fp, $row);
}


優(yōu)點(diǎn)簡單易用,非常節(jié)省內(nèi)存,不依賴第三方類庫。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 专栏| 肇东市| 邵阳县| 南陵县| 芮城县| 察隅县| 天全县| 山东| 双鸭山市| 乐安县| 龙山县| 徐闻县| 黔西县| 凤山县| 陆良县| 耒阳市| 东乡县| 巩留县| 琼结县| 宜黄县| 安新县| 黑水县| 香港 | 神农架林区| 平武县| 福建省| 五家渠市| 保德县| 五峰| 宁晋县| 察哈| 搜索| 芦山县| 砚山县| 老河口市| 阳东县| 龙泉市| 克拉玛依市| 西宁市| 芜湖县| 宣城市|