日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 >

php导出excel例子,php使用原生的方法导出excel实例分享

發(fā)布時(shí)間:2023/12/20 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 php导出excel例子,php使用原生的方法导出excel实例分享 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

1、前言

有時(shí)需要將數(shù)據(jù)庫表資源導(dǎo)出excel,做成一些報(bào)表數(shù)據(jù)。

而php導(dǎo)出excel的方法大致有幾種:使用php的類庫,進(jìn)行導(dǎo)出,如PHPExcel

使用php原生的方法進(jìn)行導(dǎo)出

而本文介紹的就是,如何通過原生方法導(dǎo)出excel

2、關(guān)鍵函數(shù)

2.1、ob輸出ob_start();

ob_get_contents

ob_end_clean

fopen

fwrite

fclose

iconv

2.2、header輸出header

iconv

3、使用ob函數(shù)進(jìn)行excel到導(dǎo)出

ob函數(shù)主要分為三步:進(jìn)行緩存的設(shè)置

讀取緩存

寫入文件

下面貼上導(dǎo)出的excel類

{ // ob函數(shù)緩存的開始

public static function start ()

{

ob_start();

} // 獲取緩存內(nèi)容

public static function save ($path)

{

$data = ob_get_contents();

ob_end_clean();

self::writeToExcel($path, $data);

} //寫到文件

private static function writeToExcel ($fn, $data)

{

$dir = self::setDir();

$fp = fopen($dir . '/'. $fn, 'wb');

fwrite($fp, $data);

fclose($fp);

} //excel默認(rèn)是GKB,所有要轉(zhuǎn)碼

public static function setChar ($value, $inchar = 'utf-8', $outchar ='gbk')

{

return iconv($inchar, $outchar, $value);//轉(zhuǎn)化編碼

}

//創(chuàng)建目錄,linux系統(tǒng)一般要寫到文件,目錄需要w謙虛,而文件需要x權(quán)限,為了省事直接建立子文件夾,可以不需要修改謙虛

public static function setDir($dirName = 'excel')

{ if(!is_dir($dirName)) {

mkdir($dirName);

} return $dirName;

}

}

4、完整頁面代碼

header('Content-Type: text/html; charset=GBK'); //excel需要GBK編碼,為了防止轉(zhuǎn)碼產(chǎn)生的亂碼,需要設(shè)置成GBK

require 'coon.php';

require 'excel.class.php';

$sql = 'select * from user';

$res = $link->query($sql); //判斷是否有發(fā)送get數(shù)據(jù)

if(isset($_GET['id'])){

$name = empty($_GET['id']) ? 'a' . rand(1000,9999) : $_GET['id'] ;

$filename = $name . '.xls'; //設(shè)置緩存的開始 Excel::start();

}?>

echo '

echo ''; //設(shè)置thead輸出

echo '

' . Excel::setChar('編號') . '';

echo '

' . Excel::setChar('用戶名') . '';

echo '

' . Excel::setChar('密碼') . '';

echo '

';?>

echo '

'; //設(shè)置tbody輸出

while($re = $res->fetch(PDO::FETCH_ASSOC)){

echo '

';

echo '

' . Excel::setChar($re['id']) . '';

echo '

' . Excel::setChar($re['user']) . '';

echo '

' . Excel::setChar($re['pwd']) . '';

echo '

';

}

echo '

';?>

}if(isset($_GET['id'])){

echo '' .Excel::setChar('完成') .'';

}else{

echo '' . Excel::setChar('導(dǎo)出') .'';

}?>

5、使用header下載excel

使用ob函數(shù)導(dǎo)出excel只能保存到服務(wù)器,不能提供下載(特殊處理下還是可以的);下面介紹使用header()函數(shù)來導(dǎo)出并下載excel

主要兩個(gè)header()函數(shù)

header("Content-type:application/vnd.ms-excel");//指定文件類型

header("Content-Disposition:filename=a.xls" ); //指定下載文件名

其他做法和ob函數(shù)的導(dǎo)出相同(下面完整代碼)

//下載主要靠這兩個(gè)

header("Content-type:application/vnd.ms-excel");//指定文件類型

header("Content-Disposition:filename=a.xls" ); //指定下載文件名require 'coon.php';

require 'excel.class.php';

$sql = 'select * from user';

$res = $link->query($sql);?>

//頁面輸出一般是不需要轉(zhuǎn)碼的,excel輸出才需要轉(zhuǎn)碼

echo '

echo ''; //設(shè)置thead輸出

echo '

' . Excel::setChar('編號') . '';

echo '

' . Excel::setChar('用戶名') . '';

echo '

' . Excel::setChar('密碼') . '';

echo '

';?>

echo '

'; //設(shè)置tbody輸出

while($re = $res->fetch(PDO::FETCH_ASSOC)){

echo '

';

echo '

' . Excel::setChar($re['id']) . '';

echo '

' . Excel::setChar($re['user']) . '';

echo '

' . Excel::setChar($re['pwd']) . '';

echo '

';

}

echo '

';?>

6、結(jié)語

這里只簡單介紹了excel的導(dǎo)出和下載,一個(gè)是使用ob()函數(shù),一個(gè)是使用header()函數(shù),兩種方法大同小異,但都需要注意的是excel需要GBK編碼,需要使用iconv函數(shù)進(jìn)行轉(zhuǎn)碼,才能保證不出現(xiàn)亂碼。

總結(jié)

以上是生活随笔為你收集整理的php导出excel例子,php使用原生的方法导出excel实例分享的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。