ホームページ >データベース >mysql チュートリアル >PHP で時間変数が複数日にまたがる場合にそれらの合計を計算するにはどうすればよいですか?
PHP での時間変数の合計の計算
PHP アプリケーションでは、時間変数に対して算術演算を実行する必要が生じる場合があります。 「HH:MM:SS」形式の文字列として表される 2 つの時間変数の合計を決定する特定のシナリオを検討してみましょう。
質問:
PHP で 2 つの時間変数を追加するにはどうすればよいですか?
答え:
PHP で 2 つの時間変数を正しく合計するには、 strtotime() 関数。ただし、この変換では小さな矛盾が生じます。具体的には、strtotime() 関数は時間を当日内のものとして解釈します。したがって、異なる日に属する 2 つの時刻を変換する場合、正しい合計を保証するためにタイムスタンプの 1 つを調整する必要があります。
解決策:
strtotime() を使用して $time1 と $time2 の両方を Unix タイムスタンプに変換します。
<code class="php">$timestamp1 = strtotime($time1); $timestamp2 = strtotime($time2);</code>
$time1 と $time2 の両方で共有される秒の差を計算します。この差は、前のタイムスタンプから午前 0 時を表す strtotime('00:00:00') を引くことで計算できます。
<code class="php">$seconds_difference = min($timestamp1, $timestamp2) - strtotime('00:00:00');</code>
$ を減算して、前のタイムスタンプを調整します。 Seconds_difference.
<code class="php">if ($timestamp1 < $timestamp2) { $timestamp1 -= $seconds_difference; } else { $timestamp2 -= $seconds_difference; }</code>
調整したタイムスタンプを加算します。
<code class="php">$timestamp_sum = $timestamp1 + $timestamp2;</code>
タイムスタンプの合計を「HH:MM:」に変換します。 date() を使用した SS" 形式。
<code class="php">$result = date('H:i:s', $timestamp_sum);</code>
$time1 = "15:20 の指定された値を使用: 00" および $time2 = "00:30:00" の場合、上記の解決策は次のようになります:
したがって、$time1 と $time2 の合計は "15:50:00" になります。<code class="php">$timestamp1 = strtotime('15:20:00'); // 55200 $timestamp2 = strtotime('00:30:00'); // 1800 $seconds_difference = min(55200, 1800) - strtotime('00:00:00'); // 1800 $timestamp1 -= $seconds_difference; // 55200 - 1800 = 53400 $timestamp_sum = $timestamp1 + $timestamp2; // 53400 + 1800 = 55200 $result = date('H:i:s', $timestamp_sum); // "15:50:00"</code>
以上がPHP で時間変数が複数日にまたがる場合にそれらの合計を計算するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。