国产成人无码一区二区三区在线_亚洲一区二区三区精品在线_国严精品久久久久久亚洲影视 _国产精品福利在线播放_中文字幕av导航_玉米视频成人免费看_国产v亚洲v天堂无码久久久_一区二区三区资源_免费成人深夜夜行视频_国产在线观看成人_一区二区三区产品免费精品久久75_国产国语videosex另类

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

詳解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號
尤物yw午夜国产精品视频明星 | 色青青草原桃花久久综合| 日韩欧美a级片| 青草热久免费精品视频| 亚洲欧美色婷婷| 国产男人搡女人免费视频| 成年人小视频在线观看| 91女神在线视频| 蜜桃网站成人| 国产精品欧美综合| 亚洲一区二区在线免费观看视频 | 久久人人97超碰精品888| 91麻豆国产在线| 精品日韩一区二区三区| 国产精品区一区二区三含羞草| 日韩av高清在线看片| v天堂中文在线| 国产在线一级片| 久久综合狠狠综合| 亚洲视频在线观看免费| 久久精品免费一区二区| 粉嫩欧美一区二区三区高清影视| 精品夜色国产国偷在线| 在线观看日批视频| 国产综合精品一区二区三区| 国产欧美一区二区三区在线| 久久久久国色av免费观看性色| 在线不卡国产精品| 亚洲精品av在线| 亚洲国产精品高清久久久| 日韩免费在线观看| 精品国产一区二区三区忘忧草| 91精品国产91热久久久做人人| 苍井空浴缸大战猛男120分钟| 综合欧美亚洲日本| 中文字幕 久热精品 视频在线| www亚洲一区| 亚洲国产欧美久久| 国产白丝精品91爽爽久久| 狠狠色丁香婷婷综合久久片| 九九九久久久精品| 高清国产一区二区三区| www.性欧美| 中文字幕免费不卡| 亚洲国产精品影院| 色av一区二区| 日韩成人av在线播放| 亚洲图片制服诱惑| 美女久久久久久久| 欧日韩不卡在线视频| 96国产粉嫩美女| 久久久久久久久四区三区| 日本10禁啪啪无遮挡免费一区二区| 相泽南亚洲一区二区在线播放 | 高清不卡在线观看| 99re66热这里只有精品3直播| 久久众筹精品私拍模特| 一区二区三区日韩在线观看| 欧美日韩精品久久久| 亚洲黄色www网站| 久久久国产影院| 国产精品三级久久久久久电影| 电影午夜精品一区二区三区| 亚洲欧洲日本国产| 婷婷六月天在线| 国产又黄又粗视频| 四虎精品永久在线| 视频在线观看一区| 欧美国产日韩在线观看| 欧美在线免费播放| 日韩在线观看免费高清完整版| 国产精品成人aaaaa网站| 日本高清不卡三区| 久久久精品麻豆| 成人免费视频入口| 一个人看的www日本高清视频| 日本视频一区二区| 亚洲精品你懂的| 亚洲成**性毛茸茸| 国产成人一区二| 欧美成人午夜激情视频| 91精品国产综合久久香蕉最新版 | 欧美激情二区三区| 99热国产免费| 欧美在线观看成人| аⅴ天堂中文在线网| 91丨九色丨蝌蚪丨对白| 99久久精品国产一区| 色综合久久久久综合99| 国产污片在线观看| 菠萝蜜影院一区二区免费| 热草久综合在线| 国产经品一区二区| 日本福利视频一区| 国产精品久久看| 一本大道综合伊人精品热热| 亚洲欧美精品伊人久久| 国产精品成人aaaaa网站| 成a人片亚洲日本久久| 日韩欧美在线视频免费观看| 秋霞欧美在线观看| 奇米777欧美一区二区| wwwxxx黄色片| 免费看日本黄色片| av av片在线看| 欧美韩国一区二区| 日韩午夜激情电影| 91精品视频在线播放| 亚洲人成色77777| 国产一级片免费| 国产传媒一区在线| 欧美一区二区在线看| 国产色综合天天综合网| 嫩草影院国产精品| 制服丝袜在线一区| 日韩美女精品在线| 久久福利视频网| 黄色高清视频网站| 五月天婷婷色综合| 99久久精品免费看| 亚洲日韩欧美视频| 日韩欧美电影一区二区| 一级片黄色录像| 国产精品99久久久久久有的能看| 91 com成人网| 国内成+人亚洲| 女尊高h男高潮呻吟| 精品在线观看免费| 欧美精品一区二区三区蜜臀| 亚洲自拍av在线| 波多野结衣 在线| 国产精品69久久久久水密桃| 亚洲精品福利资源站| 亚洲高清精品中出| 日韩精品――中文字幕| 国产精品成人午夜| 欧洲精品久久久| 久久精品无码一区二区三区毛片| 99久久婷婷国产综合| 久久中文字幕电影| 高清欧美一区二区三区| 国产乱女淫av麻豆国产| 视频一区视频二区在线观看| 亚洲第一偷拍网| 日韩小视频网址| 日韩精品中文字| 国产成人一级片| 国产精品福利一区| 日本国产精品视频| www.17c.com喷水少妇| 国产一区二区电影| 中文字幕自拍vr一区二区三区| 日本五级黄色片| 亚洲精品国产精品国自产观看| 麻豆changesxxx国产| 国产精品美女久久久久久久网站| 久久久久久久久久av| 牛夜精品久久久久久久| 美女国产一区二区三区| 伊人精品在线观看| 午夜免费福利视频在线观看| 国产原创一区二区| 欧美成人免费一级人片100| 伊人免费视频二| 成人黄页在线观看| 91超碰caoporn97人人| 国产精品第七页| 欧美国产精品一区二区| 成人免费网站在线| 国产一级特黄a高潮片| 亚洲国产一区二区视频| 精品在线视频一区二区| 男人天堂av在线播放| 日本久久精品电影| 天天综合五月天| 日韩电影在线免费看| 亚洲香蕉伊综合在人在线视看| 男人操女人免费软件| 日韩免费精品视频| 国产日本欧美视频| 一级特黄妇女高潮| 谁有免费的黄色网址| 黄色av电影网站| 久久爱另类一区二区小说| 亚洲视频一区二区在线| 亚洲国产精品va在看黑人| 日韩精品视频免费专区在线播放 | 欧美少妇一区二区| 日韩欧美亚洲一二三区| 欧美 日韩精品| 波多野结衣高清视频| 国产乱一区二区| 国产精品久久综合| 久久不卡免费视频| 六月丁香综合在线视频| 亚洲一区二区三区在线看 | 亚洲综合激情五月| 日本在线观看视频一区| 91女人18毛片水多国产| 欧美性生活大片视频| 久久网站热最新地址| 久久精品人人做人人爽| 亚洲日韩欧美视频| 欧美激情在线播放| 日韩 欧美 视频| 人妻av无码一区二区三区| 国产精品影视网| 国产精品少妇自拍| 日韩在线视频播放| 日本视频精品一区| 在线观看国产精品一区| 国内精品视频在线播放| 丝袜美腿中文字幕| 国产黄人亚洲片| 久久久久久成人精品| 亚洲欧洲精品在线 | 成人精品999| 亚洲免费成人网| 日韩精品在线观看一区二区| 青青草精品在线视频| 日本在线不卡视频| 日韩av电影在线网| 精品无码一区二区三区的天堂| 亚洲免费人成在线视频观看| 精品国产av色一区二区深夜久久 | 五月天丁香社区| 国产精品入口芒果| 日韩精品一区二区三区外面 | 亚洲天堂国产精品| 在线播放中文字幕一区| 国产乱国产乱老熟300部视频| 菠萝蜜视频在线观看一区| 国产日产亚洲精品| 啪啪一区二区三区| 夜夜夜精品看看| 国产精品旅馆在线| 这里只有精品电影| 欧美亚洲日本在线观看| 亚洲日本青草视频在线怡红院| 99精品一级欧美片免费播放| ww久久中文字幕| 欧美交换配乱吟粗大25p| 欧美国产禁国产网站cc| 国产裸体舞一区二区三区| 亚洲一区av在线| 欧美a v在线播放| 国产成人丝袜美腿| 精品日韩美女| 亚洲欧洲综合在线| 亚洲欧洲偷拍精品| 伊人国产在线视频| caoporen国产精品视频| 97超级碰碰| www.天堂在线| 玖玖玖精品中文字幕| gv天堂gv无码男同在线观看| 亚洲人成在线一二| 最新中文字幕第一页| 91精品久久久久久久久久另类| 超碰在线超碰在线| 欧美老女人性生活视频| 国产精品女同一区二区三区| 99在线看视频| 亚洲福利在线观看视频| 欧美成在线观看| 久草视频手机在线观看| 亚洲精品动漫100p| aaaaaav| 91精品国产欧美一区二区18 | www.毛片.com| 蜜月aⅴ免费一区二区三区| 国产成人亚洲精品自产在线| 精品视频久久久久久| 欧美少妇一区| 日韩欧美在线观看免费| 日韩视频第一页| 午夜精品一二三区| 久久成年人网站| 91入口在线观看| 美腿丝袜在线亚洲一区 | 美女一区视频| 亚洲欧美综合在线精品| 亚洲av网址在线| 久久久久久久久爱| 亚洲柠檬福利资源导航| 精品无码国模私拍视频| 欧美日韩中文视频| 91精品国产91久久久久久一区二区 | 久久久免费视频网站| 国产欧美一区二区在线观看| 91香蕉视频免费看| 中文字幕亚洲在线| 蜜桃久久久久久| 99热手机在线| 色妞在线综合亚洲欧美| 久久av资源站| 波多野结衣中文字幕在线播放| 久久精品视频在线| 国产成人精品亚洲日本在线桃色| 免费黄频在线观看| 欧美激情一级欧美精品| 91蜜桃传媒精品久久久一区二区| 99久久久无码国产精品性波多 | 91美女片黄在线观| 亚洲欧美在线高清| 亚洲AV成人无码网站天堂久久| 国产在线999| 香蕉乱码成人久久天堂爱免费| 国产成人亚洲精品自产在线| 日产国产精品精品a∨| 欧美裸体bbwbbwbbw| 日本高清视频网站| 可以看污的网站| 人人爽久久涩噜噜噜网站| 成人免费在线视频| 无码人妻丰满熟妇奶水区码| 一区二区三区四区免费视频| 精品久久久久久无| 久久精品国产99久久6| 女同性恋一区二区三区| 国产综合色香蕉精品| 欧美性猛交xxxx乱大交极品| 国产乱码精品一区二三区蜜臂 | 免费中文字幕在线| 欧美美乳视频网站在线观看| 日韩三级电影网址| 黄网站免费久久| 色噜噜日韩精品欧美一区二区| 91亚洲国产成人精品性色| 欧美制服丝袜第一页| 深爱激情五月婷婷| 黑森林av导航| 国产精品yjizz| 精品免费日韩av| 国产成人av影院| 久久国产精品国语对白| 亚洲欧洲三级| 最近2019中文字幕mv免费看| 国产日产欧产精品推荐色 | 小泽玛利亚一区| 欧美xxxx黑人又粗又长精品| 亚洲国产小视频| 99久久久无码国产精品| 久久久久久久久久影院| 久久久久久久久久久免费视频| 欧美在线性爱视频 | 91wwwcom在线观看| 亚洲天堂视频在线播放| 熟女视频一区二区三区| 欧美激情网友自拍| 精品人伦一区二区三区蜜桃网站| 国内爆初菊对白视频| 日韩Av无码精品| 奇米视频888战线精品播放| 尤物yw午夜国产精品视频| 亚洲三级免费电影| 欧美 日韩 人妻 高清 中文| 亚洲精品国产91| 欧美亚洲色图视频| 国产精品国语对白| 亚洲国产97在线精品一区| 国产精品美女一区二区| 人妻少妇精品无码专区| 特级西西人体高清大胆| a级黄色一级片| 97se国产在线视频| 亚洲一二三在线| 欧美日韩在线视频一区| 国产69精品一区二区亚洲孕妇| 69视频免费在线观看| 一起操在线视频| 欧美一区二区在线| 97国产在线视频| 精品国免费一区二区三区| 中文字幕日韩精品一区| 日日摸夜夜添夜夜添精品视频| 国产成人自拍网站| 国产无色aaa| 老司机av福利| 91传媒视频免费| 欧美激情久久久久| 精品久久久久久久久久久久久久久| 国产精品国产三级国产有无不卡| 国产综合在线播放| 日韩福利片在线观看| 国产一级免费片| 久久久亚洲综合网站| 国产精品三级美女白浆呻吟| 成人免费91在线看| 中国人体摄影一区二区三区| 日韩欧美在线一区二区| 欧美日韩国产免费一区二区三区| aa成人免费视频| 美女亚洲精品| 日韩av电影免费在线| 欧美日韩天天操| 国产日韩亚洲欧美在线| 日韩av免费在线观看| 欧美亚洲免费在线一区| 国产一级视频在线观看| 日本黄色的视频| 国产日韩欧美大片| 国产亚洲欧美一区二区三区| 日本a级片电影一区二区| 久久夜精品香蕉| 亚洲人成网站777色婷婷| 日韩视频免费直播| 欧美老女人在线| 欧美亚洲一区二区在线观看| 亚洲妇熟xx妇色黄|