【PHP(Laravel)】MySQLのデータを整形してExcelに出力する簡単な方法

【PHP(Laravel)】MySQLのデータを整形してExcelに出力する簡単な方法

PHP(Laravel)でMySQLのデータを整形してExcelに出力する簡単な方法

Laravel Excel というキーワードで検索している人って結構いるんだなぁ~と思い私が採用している簡単な方法を記載しておこうと思います。

Excel出力の方法は大別して2つ

LaravelでMySQLのテーブルを整形してExcelに出力する方法は2系統あります。
どんな道具を使うかにも関わる大切な所なので「自分のやりたいことにはどちらがマッチするか」を先に考えておきます。

  1. 事前準備したテンプレートの加工
  2. ゼロからのExcelファイル作成

前者は「データの入っていないExcelファイルを用意しその上にデータを張り付けていく方法」で後者は文字通り「何もない所からExcelファイルを構築する方法」です。

それぞれのメリット/デメリット

それぞれに利点と欠点がります。簡単にまとめると下の通りです。

▼事前準備したテンプレートの加工

[利点]

  • 出力に合わせた形に形成しやすい
  • 型が決まっているので構築が楽

[欠点]

  • リストのような行数が可変する場合の対応が面倒
  • 型が決まっているので、欠損情報があると目立つ

▼ゼロからのExcelファイル作成

[利点]

  • データの数によって幅や高さの調整を行えるので自由度が高い
  • 出力情報に合わせてレイアウトを変更できるため出力ごとの最適化が出来る

[欠点]

  • 高い自由度の分、コントロールする項目が多く構築が面倒
  • PDFや用紙への出力を検討する場合、変動する行数のコントロールが必要になる

ちなみに、私が作成するのは【提案書】【企画書】といった出力を伴う定型ファイルが多いのですが、これは超簡単に構築できます。

Excel出力が簡単なツールは何か

テンプレートを作成しておき、そこに値を書き込むスタイルであればPhpSpreadsheetが一番簡単です。
Laravel-Excelも利用してみましたが、ごくごく単純に出来るのはphpspreadsheetの方でした。

インストールもcomposerに指示して一発。

phpspreadsheetの簡単な使い方

段取りはこんな感じです。

  1. 出力用のコードをまとめたディレクトリ Exports を用意する
  2. 読込むテンプレートファイル(XLSX)の位置と名前を固定し準備する
  3. 出力用コードの中で PhpSpreadsheet の5つのスクリプトをUSEする
  4. どのセルに何の値を入れるか出力用のコード内で指示する
  5. 出力されたファイル(xlsx)の扱いを指示する(ダウンロードかメール送信かディレクトリ保存か)

簡単なテストコード

上のコードは用意したExcelファイルの『S列9行目』に作成したQRコードの画像を貼り付けます。

貼付け指示はたったこれだけ

PhpSpreadsheetはxlsxだけでなくCSV出力にも使えます

このプラグインはcsv出力にも使えるから使い勝手はとてもいいです。

例えば、モールの出力形式に合わせたCSVを作成する時などに十分使えます。

まぁ私はAPIで出品してしまった方が楽なのでそんな風に仕掛けてますけど、手元にCSVが欲しい方は結構いらっしゃる様なので、今後PHPスプレッドシートを使って出力を組もうかなと考えてます。

APIで出品できない(しにくい)モールもあるみたいですしね。

まとめ

このブログにもLaravel Excelと言うキーワードで訪問してくださる方がいまして、その回答をどこにも記してないので申し訳ないなと思いこんな記事を書いてみました。

私が色々と作ってきた中で『簡単』だったり『当たり前』だったりと判断して記載していない内容は結構あります。
今後、そんな情報も随時更新していこうかなと思ってます。

さぁ、今日もお仕事頑張りましょう!