从包含秒的整数中获取小时/天/周的乘数值


geting multiplier value of hour/day/week from integer containing seconds

我在这样的字段中存储总秒数:

乘数 x 小时(以秒为单位) (60*60)

乘数 x 以秒为单位的天 (60*60*24)

乘数 x 周(以秒为单位)(60*60*24*7)

用户可以输入乘数(整数值)。"小时"、"天"和"周"是固定值,因此用户只能选择其中一个选项。

我提供的 API 仅允许将此整数值存储为总秒数。

检索此值时,如何确定他们输入的乘数值是什么,以及它是否属于小时、天或周?

我目前正在用PHP开发这篇文章。任何帮助将不胜感激。

也许我可以建议这样的函数:-

/**
 * Given number of seconds will calculate if likely
 * multiplier is weeks, days, hours or seconds
 *
 * @param int $period
 * @return string representing possible chosen multiplier
 */
function getMultiplier($period)
{
    $hour = 60*60;
    $day = $hour * 24;
    $week = $day * 7;
    if($period >= $week && $period % $week == 0){
        return $period/$week . " weeks";
    }
    if($period >= $day && $period % $day == 0){
        return $period/$day . " days";
    }
    if($period >= $hour && $period % $hour == 0){
        return $period/$hour . " hours";
    }
    return "$period seconds";
}

像这样使用它:-

echo getMultiplier(60 * 60 * 23);

将输出

23小时

你说乘数必须是一个整数 - 然后你可以检查周和日的可除性,看看这是否是输入的。

如果(total_seconds/seconds_in_week)是整数,他们可能选择了"周"
如果(total_seconds/seconds_in_day)是整数,他们可能选择了"天"
否则,他们肯定会选择秒。

即使他们确实选择了 14 天之类的东西,无论如何在几周内显示可能会更好。