PHP匯出和下載excel的原生實作方法

*文
發布: 2023-03-18 09:16:02
原創
3649 人瀏覽過

相信很多小夥伴都會用到資料導出EXCEL的功能,那如何用PHP來實現導出EXCEL呢?除了PHPExcel等類別函式庫,其實原生也是可以實現的。本文就用原生程式碼來實作EXCEL的匯出。

1、前言

有時需要將資料庫表資源匯出excel,做成一些報表資料。

而php匯出excel的方法大致上有幾種:

使用php的類別庫,進行匯出,如PHPExcel

使用php原生的方法進行匯出

而本文介紹的就是,如何透過原生方法匯出excel


2、關鍵函數

2.1、ob輸出

ob_start();
ob_get_contents
ob_end_clean
fopen
fwrite
fclose
iconv
登入後複製

2.2、header輸出

header
iconv
登入後複製

3、使用ob函數進行excel到匯出

ob函數主要分為三個步驟:

进行缓存的设置
读取缓存
写入文件
登入後複製

下面貼上匯出的excel類別

登入後複製

 


4、完整頁面程式碼


query($sql);
    //判断是否有发送get数据
    if(isset($_GET['id'])){
        $name = empty($_GET['id']) ? 'a' . rand(1000,9999) : $_GET['id'] ;
        $filename = $name . '.xls';
        //设置缓存的开始
        Excel::start();
    }
?>
';
    echo '';
    //设置thead输出
    echo '' . Excel::setChar('编号') . '';
    echo '' . Excel::setChar('用户名') . '';
    echo '' . Excel::setChar('密码') . '';
    echo '';
?>
';
    //设置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 '';
?>
' .Excel::setChar('完成') .'';
}else{
    echo '' . Excel::setChar('导出') .'';
    
}
?>
登入後複製


5、使用header下載excel

使用ob函數匯出excel只能儲存到伺服器,無法提供下載(特殊處理下還是可以的);以下介紹使用header()函數來匯出並下載excel


主要兩個header()函數

header("Content-type:application/vnd.ms-excel");//指定文件类型    
header("Content-Disposition:filename=a.xls" );  //指定下载文件名
登入後複製

其他做法和ob函數的匯出相同(下面完整程式碼)


query($sql);
?>

';
    echo '';
    //设置thead输出
    echo '' . Excel::setChar('编号') . '';
    echo '' . Excel::setChar('用户名') . '';
    echo '' . Excel::setChar('密码') . '';
    echo '';
?>

';
    //设置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、結語

這裡只簡單介紹了excel的匯出和下載,一個是使用ob()函數,一個是使用header()函數,兩種方法大同小異,但都需要注意的是excel需要GBK編碼,需要使用iconv函數進行轉碼,才能確保不出現亂碼。


本文只簡單了介紹,更多高深的方法需要你自己去探索。

相關推薦:

怎麼用PHPExcel實作批次上傳表格的功能

##[課程]PHP操控Excel影片教學

#php實作excel中rank函數功能的方法


以上是PHP匯出和下載excel的原生實作方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
最新問題
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!