


Contexte
L'optimisation de l'export PHP vers Excel a été introduite dans mon article précédent : Réflexions sur le débordement de mémoire PHP Cet article présente principalement un composant avancé d'export de performances – xlswriter. , qui est une extension PHP C. Pour l'adresse officielle du document, veuillez cliquer sur .
Recommandé : Tutoriel vidéo PHP
Installation
Installer pecl
Lorsque nous constatons que pecl n'est pas installé, nous devons installer pecl. Généralement, il est installé dans le répertoire d'installation de PHP. L'exemple de commande est le suivant :
# 进入PHP安装目录 cd /usr/local/php/bin curl -o go-pear.php http://pear.php.net/go-pear.phar php go-pear.php # 安装完成后,软连接到bin目录下 ln -s /usr/local/php/bin/pecl /usr/bin/pecl
Installer xlswriter
pecl install xlswriter # 添加 extension = xlswriter.so 到 ini 配置
Utiliser
Pour une utilisation spécifique, veuillez vous référer à la documentation officielle, qui sera présentée plus en détail. Voici le code que j'utilise :
Service d'exportation encapsulé
/** * 下载 * @param $header * @param $data * @param $fileName * @param $type * @return bool * @throws */ public function download($header, $data, $fileName) { $config = [ 'path' => $this->getTmpDir() . '/', ]; $now = date('YmdHis'); $fileName = $fileName . $now . '.xlsx'; $xlsxObject = new \Vtiful\Kernel\Excel($config); // Init File $fileObject = $xlsxObject->fileName($fileName); // 设置样式 $fileHandle = $fileObject->getHandle(); $format = new \Vtiful\Kernel\Format($fileHandle); $style = $format->bold()->background( \Vtiful\Kernel\Format::COLOR_YELLOW )->align(Format::FORMAT_ALIGN_VERTICAL_CENTER)->toResource(); // Writing data to a file ...... $fileObject->header($header) ->data($data) ->freezePanes(1, 0) ->setRow('A1', 20, $style); // Outptu $filePath = $fileObject->output(); // 下载 header("Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"); header('Content-Disposition: attachment;filename="' . $fileName . '"'); header('Cache-Control: max-age=0'); header('Content-Length: ' . filesize($filePath)); header('Content-Transfer-Encoding: binary'); header('Cache-Control: must-revalidate'); header('Pragma: public'); ob_clean(); flush(); if (copy($filePath, 'php://output') === false) { throw new RuntimeException('导出失败'); } // Delete temporary file @unlink($filePath); return true; } /** * 获取临时文件夹 * @return false|string */ private function getTmpDir() { // 目录可以自定义 // return \Yii::$app->params['downloadPath']; $tmp = ini_get('upload_tmp_dir'); if ($tmp !== False && file_exists($tmp)) { return realpath($tmp); } return realpath(sys_get_temp_dir()); } /** * 读取文件 * @param $path * @param $fileName * @return array */ public function readFile($path,$fileName) { // 读取测试文件 $config = ['path' => $path]; $excel = new \Vtiful\Kernel\Excel($config); $data = $excel->openFile($fileName) ->openSheet() ->getSheetData(); return $data; }
Code d'appel
Exporter/** * 导出 */ public function actionExport() { try { /** * @var $searchModel SkuBarCodeSearch */ $searchModel = Yii::createObject(SkuBarCodeSearch::className()); $queryParams['SkuBarCodeSearch'] = []; $result = $searchModel->search($queryParams, true); $formatData = []; if (!empty($result)) { foreach ($result as $key => &$value) { $tmpData = [ 'sku_code' => $value['sku_code'], 'bar_code' => $value['bar_code'], 'created_at' => $value['created_at'], 'updated_at' => $value['updated_at'], ]; $formatData[] = array_values($tmpData); } unset($value); } $fields = [ 'sku_code' => 'SKU编码', 'bar_code' => '条形码', 'created_at' => '创建时间', 'updated_at' => '更新时间', ]; /** * @var $utilService UtilService */ $utilService = UtilService::getInstance(); $utilService->download(array_values($fields), $formatData, 'sku_single_code'); } catch (\Exception $e) { Yii::$app->getSession()->setFlash('error', '导出失败'); } }Importer
public function actionImportTmpSku() { try { /** * @var $utilService UtilService */ $utilService = UtilService::getInstance(); $path = '/tmp/'; // 文件目录 $fileName = 'sku_0320.xlsx'; $excelData = $utilService->readFile($path, $fileName); unset($excelData[0]); $excelData = array_merge($excelData); // ... ... 业务代码 } catch (\Exception $e) { echo $e->getMessage(); exit; } }
Conclusion
Après une utilisation globale, lors du traitement de grandes quantités de données, les performances sont en effet supérieures à le PHPExcel original Beaucoup.Cet article est réimprimé, l'adresse originale est : https://tsmliyun.github.io/php/PHP%E5%AF%BC%E5%87%BAExcel %E7 %9A%84%E4%BC%98%E5%8C%96/
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

php把负数转为正整数的方法:1、使用abs()函数将负数转为正数,使用intval()函数对正数取整,转为正整数,语法“intval(abs($number))”;2、利用“~”位运算符将负数取反加一,语法“~$number + 1”。

实现方法:1、使用“sleep(延迟秒数)”语句,可延迟执行函数若干秒;2、使用“time_nanosleep(延迟秒数,延迟纳秒数)”语句,可延迟执行函数若干秒和纳秒;3、使用“time_sleep_until(time()+7)”语句。

php除以100保留两位小数的方法:1、利用“/”运算符进行除法运算,语法“数值 / 100”;2、使用“number_format(除法结果, 2)”或“sprintf("%.2f",除法结果)”语句进行四舍五入的处理值,并保留两位小数。

判断方法:1、使用“strtotime("年-月-日")”语句将给定的年月日转换为时间戳格式;2、用“date("z",时间戳)+1”语句计算指定时间戳是一年的第几天。date()返回的天数是从0开始计算的,因此真实天数需要在此基础上加1。

方法:1、用“str_replace(" ","其他字符",$str)”语句,可将nbsp符替换为其他字符;2、用“preg_replace("/(\s|\ \;||\xc2\xa0)/","其他字符",$str)”语句。

php判断有没有小数点的方法:1、使用“strpos(数字字符串,'.')”语法,如果返回小数点在字符串中第一次出现的位置,则有小数点;2、使用“strrpos(数字字符串,'.')”语句,如果返回小数点在字符串中最后一次出现的位置,则有。

php字符串有下标。在PHP中,下标不仅可以应用于数组和对象,还可应用于字符串,利用字符串的下标和中括号“[]”可以访问指定索引位置的字符,并对该字符进行读写,语法“字符串名[下标值]”;字符串的下标值(索引值)只能是整数类型,起始值为0。

在php中,可以使用substr()函数来读取字符串后几个字符,只需要将该函数的第二个参数设置为负值,第三个参数省略即可;语法为“substr(字符串,-n)”,表示读取从字符串结尾处向前数第n个字符开始,直到字符串结尾的全部字符。


Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

DVWA
Damn Vulnerable Web App (DVWA) est une application Web PHP/MySQL très vulnérable. Ses principaux objectifs sont d'aider les professionnels de la sécurité à tester leurs compétences et leurs outils dans un environnement juridique, d'aider les développeurs Web à mieux comprendre le processus de sécurisation des applications Web et d'aider les enseignants/étudiants à enseigner/apprendre dans un environnement de classe. Application Web sécurité. L'objectif de DVWA est de mettre en pratique certaines des vulnérabilités Web les plus courantes via une interface simple et directe, avec différents degrés de difficulté. Veuillez noter que ce logiciel

PhpStorm version Mac
Le dernier (2018.2.1) outil de développement intégré PHP professionnel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

MinGW - GNU minimaliste pour Windows
Ce projet est en cours de migration vers osdn.net/projects/mingw, vous pouvez continuer à nous suivre là-bas. MinGW : un port Windows natif de GNU Compiler Collection (GCC), des bibliothèques d'importation et des fichiers d'en-tête librement distribuables pour la création d'applications Windows natives ; inclut des extensions du runtime MSVC pour prendre en charge la fonctionnalité C99. Tous les logiciels MinGW peuvent fonctionner sur les plates-formes Windows 64 bits.

ZendStudio 13.5.1 Mac
Puissant environnement de développement intégré PHP
