欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

PHP如何用xlswriter優(yōu)化Excel導(dǎo)出性能

這篇文章主要介紹了PHP如何用xlswriter優(yōu)化Excel導(dǎo)出性能的相關(guān)知識(shí),內(nèi)容詳細(xì)易懂,操作簡(jiǎn)單快捷,具有一定借鑒價(jià)值,相信大家閱讀完這篇PHP如何用xlswriter優(yōu)化Excel導(dǎo)出性能文章都會(huì)有所收獲,下面我們一起來(lái)看看吧。

我們提供的服務(wù)有:網(wǎng)站設(shè)計(jì)、成都做網(wǎng)站、微信公眾號(hào)開(kāi)發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認(rèn)證、新羅ssl等。為上1000+企事業(yè)單位解決了網(wǎng)站和推廣的問(wèn)題。提供周到的售前咨詢和貼心的售后服務(wù),是有科學(xué)管理、有技術(shù)的新羅網(wǎng)站制作公司

關(guān)于xlswriter

xlswriter 是一個(gè) PHP C 擴(kuò)展,旨在提升php在導(dǎo)出大數(shù)據(jù)量時(shí)的性能問(wèn)題,支持 windows / Linux 。可用于在 Excel 2007+ XLSX 文件中讀取數(shù)據(jù),插入多個(gè)工作表,寫(xiě)入文本、數(shù)字、公式、日期、圖表、圖片和超鏈接。

它具備以下特性:

一、寫(xiě)入

  • 100%兼容的 Excel XLSX 文件

  • 完整的 Excel 格式

  • 合并單元格

  • 定義工作表名稱

  • 過(guò)濾器

  • 圖表

  • 數(shù)據(jù)驗(yàn)證和下拉列表

  • 工作表 PNG/JPEG 圖像

  • 用于寫(xiě)入大文件的內(nèi)存優(yōu)化模式

  • 適用于 Linux,F(xiàn)reeBSD,OpenBSD,OS X,Windows

  • 編譯為 32 位和 64 位

  • FreeBSD 許可證

  • 唯一的依賴是 zlib

二、讀取

  • 完整讀取數(shù)據(jù)

  • 光標(biāo)讀取數(shù)據(jù)

  • 按數(shù)據(jù)類型讀取

  • xlsx 轉(zhuǎn) CSV

  • 性能對(duì)比

  • 先感謝網(wǎng)友提供數(shù)據(jù)

下載安裝

github源碼

https://github.com/viest/php-ext-xlswriter

xlswriter 文檔

https://xlswriter-docs.viest.me/zh-cn/an-zhuang/huan-jing-yao-qiu

下載 ide helper

composer require viest/php-ext-xlswriter-ide-helper:dev-master

但是我一直下載失敗,于是去github倉(cāng)庫(kù)直接下載 https://github.com/viest/php-ext-xlswriter-ide-helper
然后將里面的幾個(gè)類復(fù)制到一個(gè) xlswriter_ide_helper.php 文件里面,將這個(gè)文件放到你的項(xiàng)目中就有代碼提示了。

安裝 xlswriter 擴(kuò)展

此處在docker中安裝

docker exec -it php72-fpm bashcd /usr/local/bin
pecl install xlswriter
docker-php-ext-enable xlswriter
php -m

php --ri xlswriter
Version => 1.3.6

docker restart php72-fpm

性能測(cè)試:

測(cè)試數(shù)據(jù):20 列,每列長(zhǎng)度為 19 英文字母

Xlswriter

PHP如何用xlswriter優(yōu)化Excel導(dǎo)出性能

PHPSpreadSheet

PHP如何用xlswriter優(yōu)化Excel導(dǎo)出性能

PHP_XLSXWriter

PHP如何用xlswriter優(yōu)化Excel導(dǎo)出性能

使用示例:

private function rankPersonExport($activityInfo, $list){
    $date = date('Y-m-d');
    $filename = "{$activityInfo['orgname']}-{$activityInfo['name']}-個(gè)人排行榜-{$date}";
    $header = ['名次', '用戶ID', '對(duì)接賬號(hào)', '姓名', '電話', '部門ID', '一級(jí)部門', '二級(jí)部門', '三級(jí)部門', '總積分', '最后積分時(shí)間', "毫秒"];
    if (!empty($activityInfo['ext'])) {
        $extArr = json_decode($activityInfo['ext'], true);
        foreach ($extArr as $errItem) {
            array_push($header, $errItem['name']);
        }
    }
    // list
    $listVal = [];
    foreach($list as $v){
        $temp = [
            $v['rank'],
            $v['userid'],
            $v['userName'],
            $v['nickName'],
            $v['phone'],
            $v['departid'],
            $v['topDepartName'],
            $v['secDepartName'],
            $v['thirdDepartName'],
            $v['score'],
            $v['updatetime'],
            $v['micro'],
        ];

        if (!empty($v['ext'])) {
            $extArr = explode('|', $v['ext']);
            foreach ($extArr as $k2 => $v2) {
                $errItemArr = explode('^', $v2);
                array_push($temp, $errItemArr[1]);
            }
        }
        array_push($listVal, $temp);
    }

    $re = downloadXLSX($filename, $header, $listVal);
    if($re){
        return $this->output(0, $re);
    }else{
        return $this->output(1, 'success');
    }}
function getTmpDir(): string{
    $tmp = ini_get('upload_tmp_dir');

    if ($tmp !== False && file_exists($tmp)) {
        return realpath($tmp);
    }

    return realpath(sys_get_temp_dir());}/**
 * download xlsx file
 *
 * @param string $filename
 * @param array $header
 * @param array $list
 * @return string errmsg
 */function downloadXLSX(string $filename, array $header, array $list): string{
    try {
        $config = ['path' => getTmpDir() . '/'];
        $excel  = (new \Vtiful\Kernel\Excel($config))->fileName($filename.'.xlsx', 'Sheet1');
        $fileHandle = $excel->getHandle();
        $format1    = new \Vtiful\Kernel\Format($fileHandle);
        $format2    = new \Vtiful\Kernel\Format($fileHandle);

        // title style
        $titleStyle = $format1->fontSize(16)
            ->bold()
            ->font("Calibri")
            ->align(\Vtiful\Kernel\Format::FORMAT_ALIGN_CENTER, \Vtiful\Kernel\Format::FORMAT_ALIGN_VERTICAL_CENTER)
            ->toResource();

        // global style
        $globalStyle = $format2->fontSize(10)
            ->font("Calibri")
            ->align(\Vtiful\Kernel\Format::FORMAT_ALIGN_CENTER, \Vtiful\Kernel\Format::FORMAT_ALIGN_VERTICAL_CENTER)
            ->border(\Vtiful\Kernel\Format::BORDER_THIN)
            ->toResource();

        $headerLen = count($header);

        // header
        array_unshift($list, $header);

        // title
        $title = array_fill(1, $headerLen - 1, '');
        $title[0] = $filename;
        array_unshift($list, $title);

        $end = strtoupper(chr(65 + $headerLen - 1));
        // column style
        $excel->setColumn("A:{$end}", 15, $globalStyle);
        // title
        $excel->MergeCells("A1:{$end}1", $filename)->setRow("A1", 25, $titleStyle);
        // 凍結(jié)前兩行,列不凍結(jié)
        $excel->freezePanes(2, 0);
        // 數(shù)據(jù)
        $filePath = $excel->data($list)->output();

        header("Content-Disposition:attachment;filename={$filename}.xlsx");

        $re = copy($filePath, 'php://output');
        if ($re === false) {
            $err = 'failed to write output';
        } else {
            $err = '';
        }
        @unlink($filePath);

        return $err;
    } catch (\Vtiful\Kernel\Exception $e) {
        return $e->getMessage();
    }}

如果發(fā)現(xiàn)下載的文件有時(shí)候打不開(kāi),那應(yīng)該是你使用了官方的DEMO,問(wèn)題出在 filesize(),這個(gè)函數(shù)是有緩存的,所以你會(huì)發(fā)現(xiàn)下載下來(lái)的文件和原始的文件大小不一樣。要么像我一樣不去設(shè)置 Content-Length,要么使用 clearstatcache()手動(dòng)清除緩存。

實(shí)測(cè)5w條記錄導(dǎo)出耗時(shí)1.5s,效果還是很強(qiáng)勁的。

導(dǎo)出效果
PHP如何用xlswriter優(yōu)化Excel導(dǎo)出性能

關(guān)于“PHP如何用xlswriter優(yōu)化Excel導(dǎo)出性能”這篇文章的內(nèi)容就介紹到這里,感謝各位的閱讀!相信大家對(duì)“PHP如何用xlswriter優(yōu)化Excel導(dǎo)出性能”知識(shí)都有一定的了解,大家如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

網(wǎng)站標(biāo)題:PHP如何用xlswriter優(yōu)化Excel導(dǎo)出性能
地址分享:http://chinadenli.net/article20/gephjo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供電子商務(wù)云服務(wù)器用戶體驗(yàn)網(wǎng)站建設(shè)品牌網(wǎng)站設(shè)計(jì)網(wǎng)站設(shè)計(jì)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

搜索引擎優(yōu)化