質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

解決済

2回答

3440閲覧

PHPSpreadsheetをバージョンアップしたらエラーが出るようになりました。

退会済みユーザー

退会済みユーザー

総合スコア0

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

0クリップ

投稿2020/10/22 06:55

前提

[ O S ] Windows 10
[Server] XAMPP 7.3.22
[ PHP ] 7.4.10
[ D B ] MariaDB 10.3.15

サーバーで稼働中のワードプレスで使用するテーマがPHP7.4以降でないと動作保証できないということになり、PHPを7.3.5から7.4.1へバージョンアップを実行。
その際、自作プログラムの方で使用しているPHPSpreadsheetもうまく動作しなくなったため、こちらも1.13.1から1.14.1へバージョンアップ。

2つのプログラムで検証したところ、中身は殆ど一緒なのに、片方だけでエラーが発生。

もととなるデータは両方同じものを利用しています。
エラーが発生しない(A)の方は、合計でも6シートにWHERE条件を分けて貼り付けています。
エラーが発生してしまう(B)の方は、合計で28シートになっていて、WHERE条件を変えているだけです。

実際にはエラー表示はされるものの、プログラム自体は実行を続けていて、最終的にエクセルのシートに落とし込みも出来ています。
ただ、出力されたエクセルのシートは破損しているとアラートが表示され、シート内に配置した『図形』が、全部ではなく一部のワークシートの図形が描写されないとエラーが発生します。

特定のワークシートだけ図形が描写されないなら、そのワークシートを削除してみたりすれば回避できそうなものの、特定のワークシートとは限らず、最終のワークシートのときもあれば、複数のワークシートにまたがる場合もあります。

発生している問題・エラーメッセージ

php

1Notice: Undefined variable: exception_value in 対象コード番号

エラーの箇所が28個発生していて、大体シートに貼り付けるあたりの部分で発生しています。

該当のソースコード

PHP

1 // 初期化 2 $data = []; 3 4 // シート選択 5 $sheet = $spreadsheet->getSheetByName('SZ'); 6 7 //実施日の記入 8 $sheet->setCellValue('H2', $impDate); 9 10 //バージョン情報の記入 11 $sheet->setCellValue('B3', $revInfo); 12 13 try { 14 // DB接続時にfetchモードを指定 15 $pdo = new PDO('mysql:host=localhost;dbname=stocker_a150;charset=utf8', 'root', '', 16 [PDO::ATTR_ERRMODE=>PDO::ERRMODE_EXCEPTION, PDO::ATTR_DEFAULT_FETCH_MODE=>PDO::FETCH_ASSOC]); 17 18 foreach ($pdo->query("SELECT 19 `_mid_`, 20 `cnum_`, `cname`, `pnum_`, `bnum_`, `inum_`, 21 `dnum_`, `pname`, `psize`, `pmate`, `carea`, 22 `parea`, '前 ・ 中', NULL AS `_cmp_`, `_nq__` AS `nq01`, `_pq__`, 23 `smmtm`, `smhtm`, `smprm`, NULL AS `_spc_`, NULL AS`_tpc_`, 24 NULL AS `_oth_`, NULL AS `_clc_ `, `ratio`, `_sq__`, `_nq__` AS `nq02`, 25 `ascls`, `npart`, `pnow_`, `cpnow`, `plast`, 26 `pclss`, `_evq_`, NULL AS `_tsm_`, `upric`, `tpric`, 27 NULL AS `_8pc_`, `asnum`, `pndst`, `snum_`, `sname`, 28 `gnum_` 29 30 FROM `vw150f_main` 31 WHERE `pnum_` LIKE 'SZ%' 32 ORDER BY `cnum_`, `pnum_`, `bnum_`, `inum_` 33 34 ") 35 AS $row) { 36 $data[] = $row; 37 } 38 } 39 catch (PDOException $e) { 40 header('content-type: text/plain'); 41 die("データベース接続に失敗しました。: " . $e->getMessage() . "\n"); 42 } 43 44 if (isset($data)) { 45 $sheet->fromArray($data, $exception_value, 'A6'); 46 }

エラーが表示されるコード行には、共通して

php

1 if (isset($data)) { 2 $sheet->fromArray($data, $exception_value, 'A6'); 3 }

の部分の}のあとがエラー行として表示されます。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

Noticeはあくまでエラーではないですが、
そのNoticeに書いてある通り、どこにも$exception_value は定義されてないですね。
PHPやPhpSpreadSheetのバージョン全く関係ない現象です。
コード変わってないなら元々出ていたのではと(エラー出力レベルの設定で表示されなかっただけか)

ドキュメントを調べれば第2引数に何を設定すべきか分かるかと思います。

投稿2020/10/22 07:02

m.ts10806

総合スコア80875

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

ベストアンサー

@m.ts10806 さん

早速のご指導ありがとうございました。

php

1 if (isset($data)) { 2 $sheet->fromArray($data, $exception_value, 'A6'); 3 }

から

php

1 if (isset($data)) { 2 $sheet->fromArray($data, null, 'A6'); 3 }

へ変更したら出なくなりました。

このプログラム自体、いろんなところから抜粋し、つぎはぎだらけでもなんとか動作していたので、どこが悪いのかすら添削せずに今日まできてしまいました。

『$sheet->fromArray(』をキーワードにしてググったら、下記のサイトで【配列から値をセットする】の項目を読んで、試してみたらすぐに解決できました。
https://qiita.com/sudnonk12/items/a0d58cc0f6ff1c6e2765

本当なら、どうすればいいか答えを教えていただきたかったのですが、私へのスキルアップを配慮してくださったこと、合わせて心より感謝いたします。

投稿2020/10/22 07:43

退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

m.ts10806

2020/10/22 07:49 編集

「ドキュメント読んでください」という回答です。 PHPでもPHPマニュアル活用できないと厳しいですよ。
退会済みユーザー

退会済みユーザー

2020/10/22 08:10

ご指摘ありがとうございます。 たしかにおっしゃる通りなのですが、PHPなどを使ったプログラムを作成するSEや個人事業で、本職としてやっているなら勉強しなければと思うところです。 しかし、本職は本職で別途働いているなかで、わかる範囲内でできることを実践している分としては、現状の状態が精一杯ではあります。 ご指摘の通り、マニュアルを見て理解できるようになりたいとは思っていますので、長い目で見ていただければ幸いと存じます。
m.ts10806

2020/10/22 08:13

責めているわけではなく、自分で解決できるようになったらそれが一番早いわけですから、そのために必要な第一歩が「ドキュメントを確認する」ということになります(あとはエラーを読む、デバッグをする) 急がば回れという言葉もあるのですけど、結局プログラムは書いたとおりにしか動かないので、基礎をかためるほうが結果的に早くなります。 毎回、いつ返答があるか分からない赤の他人に聞いていては実際非効率ですからね。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問