ホームページ バックエンド開発 PHPチュートリアル xlswriter を使用して Excel エクスポートのパフォーマンスを最適化する PHP の詳細な説明 (コード例付き)

xlswriter を使用して Excel エクスポートのパフォーマンスを最適化する PHP の詳細な説明 (コード例付き)

Feb 24, 2023 pm 03:46 PM
php excel xlswriter

この記事では、PHP に関する関連知識を提供し、主に xlswriter 拡張機能とは何かについて説明します。 xlswriter 拡張機能を使用して Excel エクスポートのパフォーマンスを最適化する方法。興味のある方は以下をご覧ください。皆さんのお役に立てれば幸いです。

xlswriter について

xlswriter は、大量のデータをエクスポートする際の PHP のパフォーマンスを向上させるために設計された PHP C 拡張機能です。リナックス。 Excel 2007 XLSX ファイルのデータの読み取り、複数のワークシートの挿入、テキスト、数値、数式、日付、グラフ、画像、ハイパーリンクの書き込みに使用できます。

次の機能があります:

1. 書き込み

  • 100% 互換性のある Excel XLSX ファイル
  • 完全な Excel 形式
  • セルの結合
  • ワークシート名の定義
  • フィルター
  • グラフ
  • データ検証とドロップダウン リスト
  • ワークシート PNG/JPEG 画像
  • 大きなファイルを書き込むためのメモリ最適化モード
  • Linux、FreeBSD、OpenBSD、OS X、Windows で動作
  • 32 用にコンパイル- ビットおよび 64 ビット
  • FreeBSD ライセンス
  • 唯一の依存関係は zlib

2 です。読んでください

  • データを完全に読み取る
  • カーソルを使用してデータを読み取る
  • #データ型ごとに読み取る
  • ##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 ヘルパーのダウンロード
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

#PHPreadSheetxlswriter を使用して Excel エクスポートのパフォーマンスを最適化する PHP の詳細な説明 (コード例付き)

##PHP_XLSXWriter

xlswriter を使用して Excel エクスポートのパフォーマンスを最適化する PHP の詳細な説明 (コード例付き)

#使用例:

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 \Vtiful\Kernel\Excel($config))->fileName($filename.'.xlsx', 'Sheet1');
        $fileHandle = $excel->getHandle();
        $format1    = new \Vtiful\Kernel\Format($fileHandle);
        $format2    = new \Vtiful\Kernel\Format($fileHandle);

        // title style
        $titleStyle = $format1->fontSize(16)
            ->bold()
            ->font("Calibri")
            ->align(\Vtiful\Kernel\Format::FORMAT_ALIGN_CENTER, \Vtiful\Kernel\Format::FORMAT_ALIGN_VERTICAL_CENTER)
            ->toResource();

        // global style
        $globalStyle = $format2->fontSize(10)
            ->font("Calibri")
            ->align(\Vtiful\Kernel\Format::FORMAT_ALIGN_CENTER, \Vtiful\Kernel\Format::FORMAT_ALIGN_VERTICAL_CENTER)
            ->border(\Vtiful\Kernel\Format::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 (\Vtiful\Kernel\Exception $e) {
        return $e->getMessage();
    }}
ダウンロードしたファイルが開けない場合がある場合は、公式デモを使用している可能性があります。問題はファイルサイズにあります( )、この関数はキャッシュされるため、ダウンロードされたファイルのサイズは元のファイルとは異なることがわかります。私のように Content-Length を設定しないか、clearstatcache() を使用して手動でキャッシュをクリアしてください。

正確には、50,000 レコードをエクスポートするのに 1.5 秒かかりますが、その効果は依然として非常に強力です。

xlswriter を使用して Excel エクスポートのパフォーマンスを最適化する PHP の詳細な説明 (コード例付き)エクスポート効果

推奨学習: 「

PHP ビデオ チュートリアル

以上がxlswriter を使用して Excel エクスポートのパフォーマンスを最適化する PHP の詳細な説明 (コード例付き)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

ホットトピック

PHPの配列の操作方法 PHPの配列の操作方法 Aug 20, 2025 pm 07:01 PM

phparrayshanddedatacollectionseffictifictlyusingindexorassociativeStructures; they recreated witharray()または[]、AccessedViakeys、ModifiedByAssignment、Iterated with foreach、およびmanipulatedUsingfunctionslikecount()、in_array()、Array_key_exists()、Array_exists()、Array_exists()、Array_key_exists()、Array_key_exists()、Array_key_exists()、

PHPでのオブザーバーのデザインパターンとその実装について説明してください。 PHPでのオブザーバーのデザインパターンとその実装について説明してください。 Aug 15, 2025 pm 01:54 PM

theobserverdesignpatternablesablesはautomatic of dependentobjectswhenasubject'sstatechanges.1)itdefinesaone-to-manydependencybetweenobjects;

PHPで$ _Cookie変数を使用する方法 PHPで$ _Cookie変数を使用する方法 Aug 20, 2025 pm 07:00 PM

$ _COOKIEISAPHUPSUBLOBLOACCESSINGCOOKIESSENTBYTHESTHEBROWSER; CookiESARESETUSSETCOOKIE()beforeTput、readvia $ _cookie ['name']、updated byReshingWithNewvalues、およびdeletedBysettingAnexprideStampridectiCectiCESTAMPRAGTPRAGTPRAGTPRINESTIMESTAMPRAGTPRUCTIMESTAMPRINESTIMESTAMPRINESTIMESTAMPRINETIMESTAMPRINESTIMESTAM

phpmyAdminセキュリティベストプラクティス phpmyAdminセキュリティベストプラクティス Aug 17, 2025 am 01:56 AM

phpMyAdminを効果的に保護するには、複数のセキュリティ対策を採用する必要があります。 1. IPを介してアクセスを制限すると、信頼できるIP接続のみが許可されます。 2.デフォルトのURLパスを推測が容易ではない名前に変更します。 3.強力なパスワードを使用して、最小限の権限を備えた専用のMySQLユーザーを作成すると、2要素認証を有効にすることをお勧めします。 4.既知の脆弱性を修正するには、phpmyAdminバージョンを維持します。 5. WebサーバーとPHP構成を強化し、危険な機能を無効にし、ファイルの実行を制限します。 6。信任状の漏れを防ぐために、HTTPSに通信を暗号化するように強制します。 7. HTTP基本認証を使用していない場合、または使用していない場合はPHPMyAdminを無効にします。 8.ログを定期的に監視し、fail2banを構成して、ブルートフォースの亀裂から防御します。 9。セットアップを削除します

XSLTパラメーターを使用して、動的変換を作成します XSLTパラメーターを使用して、動的変換を作成します Aug 17, 2025 am 09:16 AM

XSLTパラメーターは、外部の通過値を介した動的変換の重要なメカニズムです。 1.宣言されたパラメーターを使用し、デフォルト値を設定します。 2。XSLTarGumentListなどのインターフェイスにアプリケーションコード(C#など)から実際の値を渡します。 3.テンプレート内の$ paramName参照パラメーターを介して、条件付き処理、ローカリゼーション、データフィルタリング、または出力形式を制御します。 4.ベストプラクティスには、意味のある名前の使用、デフォルト値の提供、関連するパラメーターのグループ化、および値の検証が含まれます。パラメーターを合理的に使用すると、XSLTスタイルのシートが非常に再利用可能で保守可能になり、同じスタイルシートが異なる入力に基づいて多様な出力結果を生成できます。

現在、NVIDIA GPUに接続されたディスプレイを使用していません[修正] 現在、NVIDIA GPUに接続されたディスプレイを使用していません[修正] Aug 19, 2025 am 12:12 AM

ifyousee "youarenotusing adisplayatchedtoannvidiagpu、" surseyourmonitoristuntedtothenvidiagpuport、configuredisissettingsintingsintingsintinginstingsintingduandcleaninstall、およびsettheprimarysodiscutodiscreteinbios/ueftereed

PHPで日付と時間を操作する方法 PHPで日付と時間を操作する方法 Aug 20, 2025 pm 06:57 PM

UsedateTimeFordatesInphp:createwithnewdateTime()、formatwithformat()、modifyviaadd()ormodify()、setimezoneswithdatetimezone、およびcompareusingoperatorsordiff()togetIntervals。

PHPで公開され、私的で、保護されているもの PHPで公開され、私的で、保護されているもの Aug 24, 2025 am 03:29 AM

公開メンバーに自由にアクセスできます。 2。プライベートメンバーはクラス内でのみアクセスできます。 3。保護されたメンバーにクラスやサブクラスにアクセスできます。 4.合理的な使用により、コードのセキュリティと保守性が向上します。

See all articles