gmnon.cn-疯狂蹂躏欧美一区二区精品,欧美精品久久久久a,高清在线视频日韩欧美,日韩免费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號
gmnon.cn-疯狂蹂躏欧美一区二区精品,欧美精品久久久久a,高清在线视频日韩欧美,日韩免费av一区二区
日韩中文字幕二区| 久久久久久久久网| 人妻少妇精品久久| 精品一区二区三区毛片| wwwwwxxxx日本| 精品www久久久久奶水| a在线视频观看| 青青青青在线视频| 丁香六月激情网| 永久免费网站视频在线观看| 黄大色黄女片18第一次| 精品少妇无遮挡毛片| 国产又大又硬又粗| 午夜免费高清视频| 亚洲一区二区三区四区五区| 亚洲高清免费在线观看| 国产一级免费大片| 日本高清免费观看| 草草草视频在线观看| 日本一本中文字幕| 日本成年人网址| 亚洲中文字幕久久精品无码喷水| 成年网站在线免费观看| 一级在线免费视频| 一级黄色大片儿| 91.com在线| 日本成人中文字幕在线| 性生活免费在线观看| 国产a级片免费看| 青草青青在线视频| 日本www高清视频| 国产三级生活片| 国产欧美日韩小视频| 国产免费人做人爱午夜视频| 中国黄色片一级| 日韩人妻无码精品久久久不卡| 国产二区视频在线| 日本中文字幕精品—区二区| 亚洲色图都市激情| 成人中文字幕av| 激情五月六月婷婷| 亚洲77777| 男人天堂新网址| 午夜免费福利在线| 少妇高潮毛片色欲ava片| 五月婷婷激情久久| 成年人网站免费视频| 午夜av中文字幕| 中文久久久久久| 日韩av三级在线| 美女av免费观看| 日韩欧美中文视频| 天天天干夜夜夜操| 日本一区二区黄色| 国产在线观看欧美| 日本中文字幕在线不卡| 久久久久免费精品| 久久久999视频| 美脚丝袜脚交一区二区| 国产av不卡一区二区| 亚洲xxx在线观看| 国模无码视频一区二区三区| 咪咪色在线视频| 日韩av片专区| 亚洲免费黄色网| 四季av一区二区三区| 尤物国产在线观看| 亚洲欧美日韩精品一区| 中文字幕第36页| 久久婷婷国产精品| 蜜臀久久99精品久久久酒店新书| 欧美在线观看成人| 亚洲自偷自拍熟女另类| 缅甸午夜性猛交xxxx| 国产精品入口芒果| 久久久久久久久久网| 国产精品专区在线| 久久久久久久中文| 国产xxxxx在线观看| 国产男女激情视频| 天堂网在线免费观看| 激情五月俺来也| 中文字幕 日韩 欧美| 亚洲欧美日本一区二区三区| 涩涩网站在线看| 欧美与动交zoz0z| 国产精品无码电影在线观看| 久久人人爽人人爽人人av| 日韩人妻无码精品久久久不卡| 久久男人资源站| 青青草原av在线播放| av网站在线不卡| 国产91视频一区| 国产v亚洲v天堂无码久久久 | 日本熟妇人妻中出| 国模私拍视频在线观看| 三上悠亚免费在线观看| 黄页网站大全在线观看| 亚洲少妇久久久| 国产又黄又爽免费视频| 无码中文字幕色专区| 日韩中文字幕a| 视色,视色影院,视色影库,视色网| 九一国产精品视频| 欧美成人福利在线观看| 欧美一区二区激情| 五月婷婷之婷婷| jizzjizz国产精品喷水| 黄色a级三级三级三级| 国产极品粉嫩福利姬萌白酱| 亚洲国产精品影视| 久久久国产欧美| 欧美激情亚洲天堂| 我要看一级黄色大片| 日本午夜激情视频| 精品国产无码在线| 人人爽人人av| 韩日视频在线观看| 91手机视频在线| 九九热精品在线播放| 无码人妻丰满熟妇区96| 黑人巨大国产9丨视频| 中文字幕在线观看第三页| 少妇大叫太大太粗太爽了a片小说| 亚洲欧美激情网| 青青青国产在线视频| 日韩小视频在线播放| 精品国产av无码一区二区三区| 中文字幕1234区| 欧美日韩中文不卡| www.激情小说.com| 爆乳熟妇一区二区三区霸乳| 91国视频在线| 国产a级片网站| 久青草视频在线播放| 久久亚洲a v| 久久手机在线视频| 国产欧美精品aaaaaa片| 9191国产视频| 国产成人在线小视频| 日本a在线天堂| 亚洲理论电影在线观看| 国产日本在线播放| 国产无限制自拍| 日日鲁鲁鲁夜夜爽爽狠狠视频97| 三年中文高清在线观看第6集| 日韩av一卡二卡三卡| 樱花草www在线| 永久免费看av| 男人用嘴添女人下身免费视频| 国产a级片网站| 男人亚洲天堂网| 高清一区在线观看| 香蕉视频xxxx| 久久久性生活视频| 国产精品亚洲αv天堂无码| 黄色三级视频在线| 香蕉视频在线网址| 欧美日韩不卡在线视频| av网站在线观看不卡| 欧美日韩一区二区三区69堂| 亚洲精品www.| 成人免费网站入口| 亚洲五月天综合| 五月天色婷婷综合| 国产a级一级片| 亚洲激情在线观看视频| 潘金莲一级淫片aaaaaa播放1| 国产人妻777人伦精品hd| 一区二区三区 欧美| 免费网站在线观看视频| 欧美女同在线观看| 久久国产午夜精品理论片最新版本| 丰满少妇被猛烈进入高清播放| 国产精欧美一区二区三区白种人| 国产午夜精品视频一区二区三区| 无码专区aaaaaa免费视频| 青青青在线视频免费观看| 无码毛片aaa在线| 成年网站在线播放| 免费毛片小视频| 97超碰在线视| 超碰成人在线播放| 国语对白做受xxxxx在线中国| 午夜影院免费版| 性刺激的欧美三级视频| www.av毛片| 欧美黄网在线观看| av磁力番号网| gogogo高清免费观看在线视频| 毛片在线视频播放| 人妻无码一区二区三区四区| 在线观看岛国av| 久久99999| 婷婷激情四射五月天| 大肉大捧一进一出好爽动态图| 日本精品久久久久久久久久| 日本丰满大乳奶| 国产又爽又黄ai换脸| 在线播放av中文字幕|