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)
    
    ?>
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 echarts动画效果失效的问题。官网下载的例子。
  • ¥60 许可证msc licensing软件报错显示已有相同版本软件,但是下一步显示无法读取日志目录。
  • ¥15 Attention is all you need 的代码运行
  • ¥15 一个服务器已经有一个系统了如果用usb再装一个系统,原来的系统会被覆盖掉吗
  • ¥15 使用esm_msa1_t12_100M_UR50S蛋白质语言模型进行零样本预测时,终端显示出了sequence handled的进度条,但是并不出结果就自动终止回到命令提示行了是怎么回事:
  • ¥15 前置放大电路与功率放大电路相连放大倍数出现问题
  • ¥30 关于<main>标签页面跳转的问题
  • ¥80 部署运行web自动化项目
  • ¥15 腾讯云如何建立同一个项目中物模型之间的联系
  • ¥30 VMware 云桌面水印如何添加