PHPにてmicrotimeで秒数を測定した際「xxxxxE-5」のような値になる場合の対応方法
PHPで過去記事を参考の上、あるプログラムの処理にかかった時間を測定しようとしたところ「4.6968460083008E-5」のように数字の最後に「E-5」という見慣れない表記が付けたされて表示されていた。調べたところ指数表記という数の表記方法らしい。以下に解決方法をメモ。
指数表記とは
Wikipediaによると数の表記方法のひとつで非常に大きな数または非常に小さな数を表記する際に利用されるとのこと。
指数表記になった原因
今回の場合は表示する秒数が非常に小さかったため指数表記になったと思われる。
例えばだが以下を実行すると「1.0E-6」が表示される。
<?php $test = 0.000001; echo $test;
解決方法
ソースコード
#number_formatを使用するパターン
$test = 0.000001;
$test = number_format($test, 10);
echo $test; //0.0000010000
#sprintfを使用するパターン
$test = 0.000001;
$test = sprintf('%F', floatval($test));
echo $test; //0.000001
所感
エクセルでも桁数の多い数値を入力した場合「E+〇」みたいな表示に自動で変更されるがこれも同じ問題みたい。ちなみにエクセルだと「列のカラム部分(A列等)を右クリック→セルの書式変換→表示形式を標準から数値に変更」で解決できる。
関連記事
-
-
PHPでユーザID毎にディレクトリを作成しキャッシュファイルを格納する方法
PHPで作ったプログラム内にてユーザーID毎に特定のディレクトリを作成し、その中 ...
-
-
PHPで土日祝日及び営業時間を考慮した上で翌○営業日を計算する方法
PHPで翌○営業日を計算したい。例えば本日が2021/04/15で翌5営業日を計 ...
-
-
PHPで月末日を取得
PHPファイルを触っている際に日付処理時、 date('t')というものがあって ...
-
-
PHPでLINEログイン後「ユーザー名」「ユーザーID」「プロフィール画像URL」「メッセージ」を取得する方法
<a>タグのリンクからページ遷移するとLINEログインし、その後に「 ...
-
-
opauthのTwitterでログインできない際の対応方法
opauthを使ったソーシャルログインのシステムにてTwitterでログインでき ...