2

我正在尝试获取此代码以从表单中的字段计算年龄。

<?php
   $birthDate = "$dob";

   $birthDate = explode("-", $birthDate);

   $age = (date("md", date("U", mktime(0, 0, 0, $birthDate[0], $birthDate[1], $birthDate[2]))) > date("md") ? ((date("Y")-$birthDate[2])-1):(date("Y")-$birthDate[2]));
   echo "Age is: ".$age;
?>

但我无法让它使用输入字段的格式,即 YYYY-MM-DD。

如果我将 $dob 更改为 PHP 使用的欧盟标准格式的日期,它就像一个魅力。

有没有一些简单的方法来纠正这个问题?

4

3 回答 3

1

始终注意日期符号(即年、月和日的顺序)。

这是有效的(改编的原始代码):

<?php
$birthDate = "1984-05-21";

$birthDate = explode("-", $birthDate);

$age = (date("md", date("U", mktime(0, 0, 0, $birthDate[2], $birthDate[1], $birthDate[0]))) > date("md") ? ((date("Y")-$birthDate[0])-1):(date("Y")-$birthDate[0]));
echo "Age is: ".$age;
?>
于 2013-03-11T15:05:57.940 回答
0

使用DateTime::diff功能

例子

<?php
$datetime1 = new DateTime('2009-10-11');
$datetime2 = new DateTime('2013-10-13');
$interval = $datetime1->diff($datetime2);
echo $interval->format('%R%y years');
?>
于 2013-03-11T15:03:32.917 回答
0

用于strtotime($dob)获取时间戳。然后以人类的方式计算年龄:

list($dob_year, $dob_date) = explode('-', date('Y-md', strtotime($dob)));
list($cur_year, $cur_date) = explode('-', date('Y-md'));

$age = $cur_year - $dob_year - ($dob_date >= $cur_date ? 0 : 1);
于 2013-03-11T15:04:11.183 回答