PHPでExcelシートを出力する方法(PhpSpreadsheet)
2024/03/13
PHPでエクセルシートを出力させたい。以前はPHPExcelを利用していたが現在は非推奨らしく後継のPhpSpreadsheetというライブラリを使うのが良いとのこと。以下に導入方法と使用方法をメモ。
公式サイト
https://phpspreadsheet.readthedocs.io/en/latest/
PhpSpreadsheetのインストール
今回のサーバはcomposerをインストールしていなかったのでそこからスタート。尚、CentOS7とPHP7.4の環境で作業した。適当なディレクトリを作成、移動し以下でインストールする。
#composerのインストール curl -sS https://getcomposer.org/installer | php mv composer.phar /usr/local/bin/composer #バージョン確認 composer --version #以下のような表示になればOK #Composer version 2.3.3 2022-04-01 22:15:35 #必要なライブラリをインストール yum --enablerepo=emi,remi-php74 install -y php-xml php-gd php-mbstring php-zip #phpSpreadsheetをインストール composer require phpoffice/phpspreadsheet
ソースコード
<?php require 'vendor/autoload.php'; use PhpOffice\PhpSpreadsheet\Spreadsheet; use PhpOffice\PhpSpreadsheet\Reader\Xls as XlsReader; use PhpOffice\PhpSpreadsheet\Reader\Xlsx as Reader; use PhpOffice\PhpSpreadsheet\Writer\Xlsx; use PhpOffice\PhpSpreadsheet\Style\NumberFormat; use PhpOffice\PhpSpreadsheet\Style\Border; use PhpOffice\PhpSpreadsheet\Style\Alignment; use PhpOffice\PhpSpreadsheet\Worksheet\Worksheet; //スプレッドシートを作成 $spreadsheet = new Spreadsheet(); //シート作成 $spreadsheet->getActiveSheet('sheet1')->UnFreezePane(); $sheet = $spreadsheet->getActiveSheet(); $sheet->setTitle("シート名"); //タイトルを設定 $sheet->setCellValue('A1', '名前'); $sheet->setCellValue('B1', '年齢'); //値を設定 $data = array( 0 => array('山田', 20,), 1 => array('鈴木', 30,), 2 => array('佐藤', 40,), 3 => array('田中', 50,), 4 => array('藤井', 60,), ); $sheet->fromArray($data, NULL, 'A2', true); //バッファをクリア ob_end_clean(); //ファイル名 $fileName = "test.xlsx"; //ダウンロード header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'); header('Content-Disposition: attachment;filename="'.$fileName.'"'); header('Cache-Control: max-age=0'); header('Cache-Control: max-age=1'); header('Expires: Mon, 26 Jul 1997 05:00:00 GMT'); header('Last-Modified: ' . gmdate('D, d M Y H:i:s') . ' GMT'); header('Cache-Control: cache, must-revalidate'); header('Pragma: public'); $writer = new Xlsx($spreadsheet); $writer->save('php://output'); exit(); ?>
所感
ちょっとしたエクセル作成なら簡単にできそう。あまり凝ったことはしないのであれば十分使えるかと。
参考サイト
https://wiblok.com/blog/spreadsheet/
関連記事
-
PHPでルーティング用ライブラリ「AltoRouter」の利用方法
PHPフレームワークのCodeIgniterを勉強していた際にルーティング機能が ...
-
PHPのHTTPリクエストライブラリ「Requests for PHP」の利用方法
PHPで外部のAPI等にリクエストする際に可能であればfile_get_cont ...
-
PHPで「php-qrcode-detector-decoder」ライブラリを使用してQRコードをデコードする方法
PHPでQRコードの画像をデコードし、値を変数等に格納したい。何とかならないか調 ...
-
HTML / CSSで作成したコンテンツをPDFファイルで出力する方法(TCPDF)
HTML / CSSで作成したコンテンツをPDFファイルで出力させたい。以前mp ...
-
PHPでシンプルな英数字のCAPTCHAを「Gregwar / Captcha」ライブラリで実装する方法
PHPでシンプルなランダム英数字のCAPTCHAを実装したい。「Gregwar ...