久久精品五月,日韩不卡视频在线观看,国产精品videossex久久发布 ,久久av综合

站長資訊網
最全最豐富的資訊網站

詳解PHP用xlswriter優化Excel導出性能(附代碼示例)

本篇文章給大家帶來了關于php的相關知識,其中主要跟大家聊一聊xlswriter擴展是什么?怎么使用xlswriter擴展優化Excel導出性能,感興趣的朋友下面一起來看一下吧,希望對大家有幫助。

關于xlswriter

xlswriter 是一個 PHP C 擴展,旨在提升php在導出大數據量時的性能問題,支持 windows / Linux ??捎糜谠?Excel 2007+ XLSX 文件中讀取數據,插入多個工作表,寫入文本、數字、公式、日期、圖表、圖片和超鏈接。

它具備以下特性:

一、寫入

  • 100%兼容的 Excel XLSX 文件
  • 完整的 Excel 格式
  • 合并單元格
  • 定義工作表名稱
  • 過濾器
  • 圖表
  • 數據驗證和下拉列表
  • 工作表 PNG/JPEG 圖像
  • 用于寫入大文件的內存優化模式
  • 適用于 Linux,FreeBSD,OpenBSD,OS X,Windows
  • 編譯為 32 位和 64 位
  • FreeBSD 許可證
  • 唯一的依賴是 zlib

二、讀取

  • 完整讀取數據
  • 光標讀取數據
  • 按數據類型讀取
  • xlsx 轉 CSV
  • 性能對比
  • 先感謝網友提供數據

下載安裝

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倉庫直接下載 https://github.com/viest/php-ext-xlswriter-ide-helper
然后將里面的幾個類復制到一個 xlswriter_ide_helper.php 文件里面,將這個文件放到你的項目中就有代碼提示了。

安裝 xlswriter 擴展

此處在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
登錄后復制

性能測試:

測試數據:20 列,每列長度為 19 英文字母

Xlswriter

詳解PHP用xlswriter優化Excel導出性能(附代碼示例)

PHPSpreadSheet

詳解PHP用xlswriter優化Excel導出性能(附代碼示例)

PHP_XLSXWriter

詳解PHP用xlswriter優化Excel導出性能(附代碼示例)

使用示例:

private function rankPersonExport($activityInfo, $list){     $date = date('Y-m-d');     $filename = "{$activityInfo['orgname']}-{$activityInfo['name']}-個人排行榜-{$date}";     $header = ['名次', '用戶ID', '對接賬號', '姓名', '電話', '部門ID', '一級部門', '二級部門', '三級部門', '總積分', '最后積分時間', "毫秒"];     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 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);         // 凍結前兩行,列不凍結         $excel->freezePanes(2, 0);         // 數據         $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();     }}
登錄后復制

如果發現下載的文件有時候打不開,那應該是你使用了官方的DEMO,問題出在 filesize(),這個函數是有緩存的,所以你會發現下載下來的文件和原始的文件大小不一樣。要么像我一樣不去設置 Content-Length,要么使用 clearstatcache()手動清除緩存。

實測5w條記錄導出耗時1.5s,效果還是很強勁的。

導出效果
詳解PHP用xlswriter優化Excel導出性能(附代碼示例)

推薦學習:《PHP視頻教程》

贊(0)
分享到: 更多 (0)
?
網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
久久精品五月,日韩不卡视频在线观看,国产精品videossex久久发布 ,久久av综合
国产欧美一级| 亚洲丝袜啪啪| 国产欧美一区二区三区国产幕精品 | 成人羞羞视频播放网站| 精品伊人久久久| 国产精品传媒麻豆hd| 国产日韩中文在线中文字幕 | 日本大胆欧美人术艺术动态| 水蜜桃久久夜色精品一区的特点 | 影视先锋久久| 黄色成人91| 蜜桃久久久久久久| 日韩中文字幕在线一区| 日韩和欧美一区二区三区| **爰片久久毛片| 国产欧美日韩亚洲一区二区三区| 国产精品www994| 国产极品模特精品一二| 久久麻豆视频| 成人精品久久| 久久国产日韩| 亚洲一区二区毛片| 奇米狠狠一区二区三区| 国产精品第一| 中文字幕在线官网| 99久久精品网站| 在线视频亚洲| 亚洲精品影院在线观看| 欧美影院视频| 免费亚洲一区| www.九色在线| 99热精品在线观看| 亚洲精品日本| 久久一区欧美| 国产综合婷婷| 亚洲精品乱码| 美女久久久精品| 三级小说欧洲区亚洲区| 在线亚洲免费| 国产精品日本一区二区三区在线 | 在线日韩电影| 天堂成人免费av电影一区| 欧美一级网址| 欧美三级网址| 日韩在线网址| 日韩欧美精品一区| 中文字幕一区二区三区日韩精品| 免费在线日韩av| 欧美丝袜一区| 日本不卡一区二区| 桃色av一区二区| 三级在线观看一区二区| 久久97久久97精品免视看秋霞| 亚洲天堂黄色| 国产午夜久久av| 久久狠狠婷婷| 91精品在线免费视频| 黄在线观看免费网站ktv| 一区二区精彩视频| 亚洲黄色网址| 91久久精品无嫩草影院| 欧美性感美女一区二区 | 国产一区日韩| 蜜桃久久av一区| 成人黄色av| 日韩精品一区二区三区中文字幕| 亚洲一级少妇| 欧美日韩18| 亚洲国产不卡| 日韩精品免费视频人成| 久久久久久久久久久9不雅视频| 涩涩涩久久久成人精品| 日本美女一区| 国产精品亚洲欧美| 美女精品在线| 福利视频一区| 日韩精品91亚洲二区在线观看| 亚洲不卡系列| 久久不卡国产精品一区二区| 亚洲一区二区毛片| 日韩精品dvd| 国产高清亚洲| 亚洲久久在线| 狠狠干成人综合网| 麻豆成人av在线| 热久久久久久久| 999国产精品视频| 国产中文字幕一区二区三区| 亚洲精品伊人| 亚洲国产日韩欧美在线| 91一区二区| 欧美激情一区| 日韩精品a在线观看91| 久久99国产精品视频| 国产精品.xx视频.xxtv| 日本欧洲一区二区| 亚洲一级特黄| 精品九九在线| 国产日本久久| 在线视频精品| 国产一区二区中文| а√天堂8资源在线| 国产精品最新| 欧美精品影院| 日韩欧美2区| 亚洲香蕉久久| 人人爽香蕉精品| 亚洲激情黄色| 一区二区小说| 日韩精品久久久久久久电影99爱| 麻豆久久久久久| 国产一卡不卡| 日本三级亚洲精品| 综合色一区二区| 国产精品视区| 亚洲欧美激情诱惑| 好吊日精品视频| 激情五月综合| 亚洲激情二区| 性欧美长视频| 亚洲主播在线| 亚洲一级大片| 日韩精品一区二区三区中文字幕| 麻豆精品网站| 中文一区一区三区免费在线观 | 99国产精品免费视频观看| 欧美天堂视频| 成人精品天堂一区二区三区| 日韩一区二区三区免费播放| 精品视频网站| 日本精品黄色| 正在播放日韩精品| 日韩欧美三级| 欧美日韩亚洲在线观看| 免费毛片在线不卡| 国产视频一区三区| 日韩中文字幕1| 四虎在线精品| 国产亚洲电影| 久久中文字幕一区二区| 国产一区二区三区国产精品| 福利在线一区| 欧美亚洲国产精品久久| 成人av动漫在线观看| 99国产精品视频免费观看一公开| 久久亚洲欧美| 亚洲区国产区| 国产精品亚洲成在人线| 精品91福利视频| 日韩一区二区三区免费播放| 久久麻豆精品| 视频一区中文字幕| 日本国产欧美| 精品国产午夜肉伦伦影院| 精品久久中文| 久久久夜夜夜| 在线精品视频一区| 国产情侣一区| 麻豆成全视频免费观看在线看| 日韩精品久久久久久久电影99爱| 美女少妇全过程你懂的久久| 视频精品一区二区| 日韩一区二区三区四区五区| 欧美成人精品午夜一区二区| 精品国产免费人成网站| 亚洲视频播放| 国产精品一区亚洲| 免费在线小视频| 中文字幕亚洲精品乱码| 久久99国产精品视频| 国产一区二区三区自拍| 色狠狠一区二区三区| 精品一区二区三区四区五区| 91精品国产乱码久久久久久久| 亚洲手机视频| 亚洲精品在线国产| 精品国产成人| 激情欧美国产欧美| 日韩欧美在线精品| 日韩精品中文字幕第1页| 美女久久一区| 麻豆高清免费国产一区| 国产成人77亚洲精品www| 亚洲免费精品| 欧美激情视频一区二区三区免费 | 91精品蜜臀一区二区三区在线| 亚洲精品高潮| 日韩影院二区| 97久久超碰| 久久五月天小说| 91精品国产一区二区在线观看| 涩涩av在线| 91精品在线免费视频| 亚洲黑丝一区二区| 国产精品久久久久久久久久白浆| 激情婷婷亚洲| 欧美专区一区| 影音先锋国产精品| 精品三级在线| 日韩**一区毛片|