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

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

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

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

Q&A

解決済

1回答

1919閲覧

phpspreadsheetで取得する値がExcelの値と異なる

kumamonmon

総合スコア13

PHP

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

0グッド

1クリップ

投稿2019/03/15 06:03

phpspreadsheetを使って、Excelのデータを取得しています。
ほとんどのセルは問題なく値を取得できていますが、
Excelのセルの値と全然違う値を取得する箇所があります。


Excelの値:290000000
phpspreadsheetで取得した値:-309390000

取得はgetCalculatedValue()を利用しています。
getCalculatedValue()だと正しい結果が取得できませんが、
getOldCalculatedValue()だと正しい結果が取得できます。

getOldCalculatedValue()を使うべきなのでしょうか。
getOldCalculatedValue()は非推奨というような記載を見かけたので、できれば使いたくないです。

原因や解決方法など、ご存知の方教えてください。
よろしくお願いします。

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

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

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

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

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

guest

回答1

0

ベストアンサー

まず、getCaluculatedvValue()メソッドはPhpspreadsheetでは非推奨となっています。よって、代替の手段が必要です。ところが、Phpspreadsheetはけっこうバグだらけなので、信頼できない動作をするものは使わないほうがいいです。

これは自分が実務で利用しているものですが、この書き方なら14桁までの数値(ゼロ先頭でも問題ありません)まで処理できます(文字列だと困る場合は後ろのメソッドを消してください)

PHP

1getNumberFormat() -> setFormatCode('0');

投稿2019/03/15 07:39

編集2019/03/15 07:47
FKM

総合スコア3608

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

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

kumamonmon

2019/03/15 09:39

やはり非推奨なのですね・・・。 記載いただいた内容で解決できました! ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問