php减去两个持续时间并减少百分比以获得最终时间

标签 php math time percentage duration

我将持续时间值存储在数据库中,以了解在给定的工作周内我必须完成多少工作。例如,我有以下输入来根据总持续时间、减少的持续时间(例如午餐时间、 session 、厕所休息时间等)以及减少的百分比来计算一周内的容量持续时间。例如,我有以下值:

$total_duration = 30:30:00; //(37 hours 30 mins 00 secs)
$reduced_duration = 01:00:00; //(1 hour 00 mins 00 secs)
$capacity_percentage = 90%; // capacity percentage for leeway

因此,我想要从 $reduced_duration 中减去 $total_duration,然后获取总数的 $capacity_percentage %。

我正在尝试以下操作;

    $total_duration = '30:30:00'; //(37 hours 30 mins 00 secs)
    $reduced_duration= '01:00:00'; //(1 hour 00 mins 00 secs)
    $capacity_percentage ='90%'; // capacity percentage for leeway

    $total_duration_hrs = 0;
    $total_duration_mins = 0;
    $total_duration_secs = 0;

    $reduced_duration_hrs = 0;
    $reduced_duration_mins = 0;
    $reduced_duration_secs = 0;

    list($total_duration_hours, $total_duration_minutes, $total_duration_minutes) = explode(':', $total_duration);

    list($reduced_duration_hours, $reduced_duration_minutes, $reduced_duration_seconds) = explode(':', $reduced_duration);

    $total_duration_hrs += (int) $total_duration_hours;
    $total_duration_mins += (int) $total_duration_minutes;
    $total_duration_secs += (int) $total_duration_minutes;

    $reduced_duration_hrs += (int) $reduced_duration_hours;
    $reduced_duration_mins += (int) $reduced_duration_minutes;
    $reduced_duration_secs += (int) $reduced_duration_seconds;

    $totalhrs = ($total_duration_hrs - $reduced_duration_hrs);
    $totalmins = ($total_duration_mins - $reduced_duration_mins);
    $totalsecs = ($total_duration_secs - $reduced_duration_secs);

这给了我正确的总时间,即29:30:30。但现在我有点不确定如何找到百分比时间值,我会找到 90% 的小时、分钟和秒还是会做其他事情?大家有什么想法吗?

最佳答案

如果您在几秒钟内完成所有操作,并且仅在想要输出或读取值时将其转换为小时、分钟、秒,则会更容易。这样你的逻辑就会变得更简单并且更少地依赖于状态。

编写一个函数将秒转换为小时:分钟:秒

function secondsToFormat($seconds) {
    $diff = (new DateTime)->sub(new DateInterval("PT{$seconds}S"))->diff(new DateTime);
    $h = $diff->format("%h") + $diff->format("%a") * 24;
    return $diff->format("{$h}:%I:%S");
}

编写一个将小时:分钟:秒转换为秒的函数

现在您需要一个执行相反操作的函数,以便您可以轻松地在两者之间进行转换。

function formatToSeconds($formattedTimeString) {
    list($hours, $minutes, $seconds) = explode(":", $formattedTimeString);
    $seconds += $hours * 60 * 60;
    $seconds += $minutes * 60;
    return $seconds;
}

编写一个函数来计算占总数的百分比

function getPercentage($total, $percent) {
    return (int) floor($total / 100 * $percent);
}

现在您可以简单地执行此操作...

$t = formatToSeconds($total_duration);
$r = formatToSeconds($reduced_duration);
$diff = $t - $r; // difference in seconds
echo secondsToFormat(getPercentage($diff, 90)), " at 90% capacity";

您会得到类似于 26:33:00 at 90% 容量

关于php减去两个持续时间并减少百分比以获得最终时间,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33848323/

相关文章:

time - gstreamer:如何改变从文件中提取的一个流的渲染时间

php - 使用更新表集使用 PHP 更新表失败

java - Java 中 sin(x) 的泰勒级数

algorithm - 更快的数学算法牺牲准确性

c++ - 为什么函数立即完成一次循环,然后再次运行?

java - 在时间复杂度很重要的情况下从值数组映射键值

java - 游戏循环中的固定时间步长

php - 在 WordPress 常规设置页面中排序输入字段

php - 从 PHP 站点执行 python 脚本——我需要 Django 吗?可以在树莓派上完成吗?

php - $_FILE 中的 size 元素代表什么?