Рассчитать разницу в дате в данном формате в PHP4 - PullRequest
1 голос
/ 22 января 2011

Мне нужна функция в php4, которая будет вычислять разницу дат в предоставленном формате даты.например.

$date1 = "2011-08-24 10:03:00";
$date2 = "2012-09-24 10:04:31";
$format1 = "Y W" ; //This format should return the difference in Year and week.
$format2 = "M D"; // This format should return the difference in Months and days.
// The format can be any combination of Year,Month,Day,Week,Hour,Minute,Second.

function ConvertDate($data1,$date2,$format) 

Пожалуйста, дайте мне знать, если вам нужна дополнительная информация по этому вопросу.Заранее спасибо.

Ответы [ 2 ]

3 голосов
/ 23 января 2011

Давайте попробуем что-то вроде этого.

function ConvertDate($date1, $date2, $format)
{
    static $formatDefinitions = array(
        'Y' => 31536000,
        'M' => 2592000,
        'W' => 604800,
        'D' => 86400,
        'H' => 3600,
        'i' => 60,
        's' => 1
    );

    $ts1 = strtotime($date1);
    $ts2 = strtotime($date2);
    $delta = abs($ts1 - $ts2);

    $seconds = array();
    foreach ($formatDefinitions as $definition => $divider) {
        if (false !== strpos($format, $definition)) {
            $seconds[$definition] = floor($delta / $divider);
            $delta = $delta % $divider;
        }
    }

    return strtr($format, $seconds);
}

Просто имейте в виду, что месяцы и годы являются только приблизительными, потому что вы не можете сказать, «сколько секунд - месяц» (потому что «месяц» может быть любым между 28 и 31 днем). Моя функция считает месяц как 30 дней.

3 голосов
/ 22 января 2011

Получите метки времени Unix ваших дат, используя mktime .Тогда вы получите разницу для:

$years = floor(($date2-$date1)/31536000);
$months = floor(($date2-$date1)/2628000);
$days = floor(($date2-$date1)/86400);
$hours = floor(($date2-$date1)/3600);
$minutes = floor(($date2-$date1)/60);
$seconds = ($date2-$date1);

Надеюсь, это поможет.
—Альберто

...