站長(zhǎng)資訊網(wǎng)
        最全最豐富的資訊網(wǎng)站

        詳解PHP用xlswriter優(yōu)化Excel導(dǎo)出性能(附代碼示例)

        本篇文章給大家?guī)砹岁P(guān)于php的相關(guān)知識(shí),其中主要跟大家聊一聊xlswriter擴(kuò)展是什么?怎么使用xlswriter擴(kuò)展優(yōu)化Excel導(dǎo)出性能,感興趣的朋友下面一起來看一下吧,希望對(duì)大家有幫助。

        關(guān)于xlswriter

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

        它具備以下特性:

        一、寫入

        • 100%兼容的 Excel XLSX 文件
        • 完整的 Excel 格式
        • 合并單元格
        • 定義工作表名稱
        • 過濾器
        • 圖表
        • 數(shù)據(jù)驗(yàn)證和下拉列表
        • 工作表 PNG/JPEG 圖像
        • 用于寫入大文件的內(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
        登錄后復(fù)制

        xlswriter 文檔

        https://xlswriter-docs.viest.me/zh-cn/an-zhuang/huan-jing-yao-qiu
        登錄后復(fù)制

        下載 ide helper

        composer require viest/php-ext-xlswriter-ide-helper:dev-master
        登錄后復(fù)制

        但是我一直下載失敗,于是去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
        登錄后復(fù)制

        性能測(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');     }}
        登錄后復(fù)制

        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 VtifulKernelExcel($config))->fileName($filename.'.xlsx', 'Sheet1');         $fileHandle = $excel->getHandle();         $format1    = new VtifulKernelFormat($fileHandle);         $format2    = new VtifulKernelFormat($fileHandle);          // title style         $titleStyle = $format1->fontSize(16)             ->bold()             ->font("Calibri")             ->align(VtifulKernelFormat::FORMAT_ALIGN_CENTER, VtifulKernelFormat::FORMAT_ALIGN_VERTICAL_CENTER)             ->toResource();          // global style         $globalStyle = $format2->fontSize(10)             ->font("Calibri")             ->align(VtifulKernelFormat::FORMAT_ALIGN_CENTER, VtifulKernelFormat::FORMAT_ALIGN_VERTICAL_CENTER)             ->border(VtifulKernelFormat::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 (VtifulKernelException $e) {         return $e->getMessage();     }}
        登錄后復(fù)制

        如果發(fā)現(xiàn)下載的文件有時(shí)候打不開,那應(yīng)該是你使用了官方的DEMO,問題出在 filesize(),這個(gè)函數(shù)是有緩存的,所以你會(huì)發(fā)現(xiàn)下載下來的文件和原始的文件大小不一樣。要么像我一樣不去設(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)出性能(附代碼示例)

        推薦學(xué)習(xí):《PHP視頻教程》

        贊(0)
        分享到: 更多 (0)
        網(wǎng)站地圖   滬ICP備18035694號(hào)-2    滬公網(wǎng)安備31011702889846號(hào)
        主站蜘蛛池模板: 亚洲一二成人精品区| 精品人伦一区二区三区潘金莲| 亚洲精品高清在线| 久久久久一级精品亚洲国产成人综合AV区 | 欧美精品人人做人人爱视频| 久久精品综合一区二区三区| 国产一区二区精品久久| 狠狠色伊人久久精品综合网| 亚洲欧美日韩国产精品| 日韩精品乱码AV一区二区| 97久久超碰国产精品旧版| 99久久精品这里只有精品| 精品国精品国产自在久国产应用男 | 精品福利资源在线| 欧美日韩人妻精品一区二区在线| 国产精品一区二区久久国产| 国产精品福利在线观看| 国产成人综合精品一区| 97久久超碰国产精品2021| 精品无码人妻一区二区三区 | 久久人人爽人人精品视频| 亚洲国产精品久久| 国产精品高清一区二区三区不卡| 久久99精品久久久久久噜噜| 亚洲国产精品SSS在线观看AV| 亚洲精品色婷婷在线影院| 99久久夜色精品国产网站| 欧美国产日韩精品| 欧美日韩国产精品系列| 国产成人精品免费视频大全| 久久精品国产半推半就| 久久成人精品视频| 色偷偷888欧美精品久久久| 一区二区三区精品| 国产精品色视频ⅹxxx | 九九久久精品无码专区| 国产精品亚洲欧美大片在线看| 无码人妻精品一区二区三区66| 亚洲综合精品香蕉久久网| 亚洲国产精品嫩草影院| 2022国内精品免费福利视频 |