duanjian9148 2015-05-21 08:17
浏览 39
已采纳

为什么时间减法在回显后返回1而不是0

I have this table in my view

  duty   |  exact   |  undertime
12:00:00 | 12:00:00 | 01:00:00

undertime is the result of $hour = $duty - $exact, and when i

echo date("H:i:s",$hour);

it echoed 01:00:00, im expecting 00:00:00 for this. What did i miss?

here are my code, i use foreach because the duty and exact datas are from my database query.

<?php foreach($unique_date as $unique_dates):?>  
                <tr>
                  <td align="center" colspan="2">
                      <?php echo date($unique_dates['dtr_date']);?>
                  </td>
                  <td align="center" colspan="2">
                      <?php $timediffs = $unique_dates['timediffs'];
                            echo $timediffs;
                      ?>
                  </td>
                  <td align="center" colspan="2">
                      <?php $exact_total_sched = $unique_dates['exact_total_sched'];
                            echo $exact_total_sched;
                      ?>
                  </td>
                  <?php                         
                        $duty = strtotime($timediffs);
                        $exact = strtotime($exact_total_sched);
                  ?>
                  <?php
                        if($duty < $exact)
                        {
                          echo "<td align=\"center\" colspan=\"2\">";
                                #UNDERTIME  
                                $hour1 = $exact-$duty;
                                echo date("H:i:s",$hour1);
                          echo "</td>";
                          echo "<td align=\"center\" colspan=\"2\">";
                          echo date("00:00:00");
                          echo "</td>";
                        }
                     else if($duty > $exact)
                       {
                          echo "<td align=\"center\" colspan=\"2\">";
                           echo date("00:00:00");
                          echo "</td>";
                          echo "<td align=\"center\" colspan=\"2\">";
                                #OVERTIME
                                $hour2 = $duty-$exact;
                               echo date("H:i:s",$hour2);
                          echo "</td>";
                       }
                      else if($duty == $exact)
                       {
                          echo "<td align=\"center\" colspan=\"2\">";
                                $hour3 = $duty-$exact;
                          echo date("H:i:s",$hour3);
                          echo "</td>";
                          echo "<td align=\"center\" colspan=\"2\">";
                          echo date("00:00:00");
                          echo "</td>";
                       }
                      ?> 
                </tr>

              <?php endforeach ?>   
  • 写回答

2条回答 默认 最新

  • dty47696 2015-05-21 08:50
    关注

    You can use DateTime function along with date_diff as

    $date1=new DateTime("12:00:00");
    $date2=new DateTime("12:00:00");
    $diff = date_diff($date2,$date1);
    echo $diff->format('%H:%i:%s');
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 如何将下列的“无限压缩存储器”设计出来
  • ¥15 下图接收小电路,谁知道原理
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度
  • ¥30 关于#r语言#的问题:如何对R语言中mfgarch包中构建的garch-midas模型进行样本内长期波动率预测和样本外长期波动率预测
  • ¥15 ETLCloud 处理json多层级问题
  • ¥15 matlab中使用gurobi时报错
  • ¥15 这个主板怎么能扩出一两个sata口
  • ¥15 不是,这到底错哪儿了😭