doujianwei8217 2016-11-07 15:09
浏览 229
已采纳

将int echo毫秒转换为分钟和秒

I have a php query that is getting a field from my database that contains an int, for example 7800. I know that 7800 is 7.7 seconds or 0.13 minutes.

I need a way to display this as 00:00:08 (rounded up)

The table print out looks like this:

<td><?= $row["timeSpent"] ?></td>

It prints out 7800

I need 00:00:08 (H,M,S)

It's kept as an int in the database, not datetime

I have tried:

    <td><? echo gmdate("H:i:s",  $row['timeSpent']); ?></td>

Except 7.8 seconds prints as 02:10:00

  • 写回答

1条回答 默认 最新

  • duanpu1963 2016-11-07 15:24
    关注

    You just have to use the divide and modulo operators to build your variables, and str_pad to populate your string bits with leading zeros :

    <?php 
    
    function convertToTime($time) {
        $time = round($time/1000);
        $hours = floor($time/3600);
        $time = $time%3600;
        $minutes = floor($time/60);
        $seconds = $time%60;
        return str_pad($hours, 2, '0',STR_PAD_LEFT) . ':' . str_pad($minutes, 2, '0',STR_PAD_LEFT) . ':' . str_pad($seconds, 2, '0',STR_PAD_LEFT);
    }
    
    var_dump(convertToTime(7800)); // string '00:00:08' (length=8)
    var_dump(convertToTime(60000)); // string '00:01:00' (length=8)
    var_dump(convertToTime(3600000)); // string '01:00:00' (length=8)
    var_dump(convertToTime(42687000)); // string '11:51:27' (length=8)
    
    ?>
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥50 silvaco GaN HEMT有栅极场板的击穿电压仿真问题
  • ¥15 谁会P4语言啊,我想请教一下
  • ¥20 win11无法启动 持续蓝屏且系统还原失败,无法开启系统保护
  • ¥15 哪个tomcat中startup一直一闪而过 找不出问题
  • ¥15 这个怎么改成直流激励源给加热电阻提供5a电流呀
  • ¥50 求解vmware的网络模式问题 别拿AI回答
  • ¥24 EFS加密后,在同一台电脑解密出错,证书界面找不到对应指纹的证书,未备份证书,求在原电脑解密的方法,可行即采纳
  • ¥15 springboot 3.0 实现Security 6.x版本集成
  • ¥15 PHP-8.1 镜像无法用dockerfile里的CMD命令启动 只能进入容器启动,如何解决?(操作系统-ubuntu)
  • ¥30 请帮我解决一下下面六个代码