39

我正在编写一个脚本,该脚本将从 CSV 文件中导入一些数据。当我这样做时,我希望能够检查一个变量,看看它是否是一个有效的日期字符串。

我已经看到了几种检查字符串是否为日期的方法,但大多数方法都要求您现在使用格式。我不知道日期的格式。

现在我正在使用 strtotime(),但这并不容易

$field ="May";
if(strtotime($field)){
    echo "This is a date";
}

在这种情况下,“May”是人的名字,而不是日期。

谁能推荐更可靠的功能?

根据你们中的一些人提出的问题进行编辑。

对于在我的情况下作为“日期”传递的变量,它需要特定于日/月/年,所以只是“五月”会模糊计算。

基于此和下面 Pauls 的好点,我们还可以测试该字符串是否包含数字,例如

$field ="May";
if(strtotime($field) && 1 === preg_match('~[0-9]~', $field)){
    echo "This is a date";
}else{
    echo "Nope not a date";
}

这似乎满足了我的迫切需求,但任何人都可以发现任何问题或提出改进建议吗?

4

3 回答 3

57

使用date_parse并检查返回数组的值

$date = date_parse("May")

// ["year"] == FALSE
// ["month"] == 5
// ["day"] == FALSE

您也可以将它们传递给checkdate

$date = date_parse($someString);
if ($date["error_count"] == 0 && checkdate($date["month"], $date["day"], $date["year"]))
    echo "Valid date";
else
    echo "Invalid date";
于 2012-05-21T20:42:06.030 回答
5

我不认为这个问题有一个多合一的答案。根据您的用例,您可能有不同的策略。

strtotime()是一个完美的解决方案,但正如你所说,你最终可能会误报。为什么?因为可能是一个词或一个名字。然而,结果是strtotime('May')什么?

echo date(DateTime::ISO8601, strtotime('May'));
2012-05-21T00:00:00+0200

因此,仅给出月份将返回当前年份的日期和当前日期,从给定月份的午夜开始。一个可能的解决方案是检查您的字符串是否包含当前日期和/或当前年份,这样,您可以检查以确保您的日期是完全合格的日期并且有效。

echo date(DateTime::ISO8601, strtotime('May Day')); // (strtotime() returns false)
1970-01-01T01:00:00+0100

echo date(DateTime::ISO8601, strtotime('May 21'));
2012-05-21T00:00:00+0200

一个简单strpos()的甚至一个正则表达式就可以解决问题。

但是,它有点奇怪,只有在您没有其他方法时才应该使用。

我相信更好的解决方案是定义一组有效格式并插入结果以确保日期有效。

$validDateFormatPatterns = array(
 '[0-9]{1,2}-[0-9]{1,2}-[0-9]{4}', // 21-05-2012, obviously this pattern is simple and would accept 05-21-2012,
 'the [0-9]{1,2}(th|st|nd|rd) (January|February|...|May|...|December) [0,9]{4}', // The 21st May 2012
);

您应该尝试涵盖大部分情况,我相信您将能够找到检查最新日期格式的正则表达式。

在任何情况下,您可能需要不时调整您的功能,因为没有简单的方法可以使其防弹。

于 2012-05-21T20:39:09.323 回答
0

我知道这是很久以前问过的,但是四处寻找这个并试图避免正则表达式,我想出了这个:

function checkInputIsDate($date) {
    return (bool)strpbrk($date,1234567890) && strtotime($date);
}

这是有效的,因为它消除了上面发布的问题,即通过strtotime确保字符串中有数字strpbrk以及验证strtotime输出日期来传递仅一个月。

并了解了一个我不知道存在的功能。

希望这可以帮助某人。

于 2016-01-10T05:00:25.753 回答