gpt4 book ai didi

php - URL 中的日期 dd/mm/yyyy

转载 作者:行者123 更新时间:2023-11-29 19:00:51 25 4
gpt4 key购买 nike

我正在使用以下格式在 URL 中传递日期 (dd/mm/yyyy):

http://www.website.com/_parameter=20/02/2000

我正在使用以下 PHP 将其转换为 YYYY-MM-DD 格式。

<?php

$D->query = '';

if ($this->param('_parameter')) $D->query = date('Y-m-d', strtotime($this->param('_parameter')));

?>

我的数据库如下:

SELECT idtask FROM task WHERE unfinish=1 AND date LIKE '%".$D->query."%' "

上面返回以下内容:

1970-01-01

最佳答案

当使用strotime()时您需要确保您使用的是 valid datetime format 。否则,strtotime() 将返回 false 给您一个意外的值。

使用 XX/XX/XXXX 格式的日期假定为美国格式,这意味着前两位数字代表月份,接下来的两位数字代表月份中的日期,最后四位数字代表年份。当使用破折号时,日期被假定为欧洲格式。例如:

04/18/2017 = April 18, 2017
12/18/2017 = December 18, 2017
18-04-2017 = April 18, 2017
18-12-2017 = December 18, 2017

如果您不小心切换了日期和月份,strtotime() 将返回 false,因为日期无效。

18/04/2017 // error
18/12/2017 // error
04-18-2018 // error
12-18-2017 // error

上面的例子很简单。但当日期不明确时,您可能会遇到问题。例如:

04/12/2017 = April 12, 2017
12/04/2017 = December 4, 2017
04-12-2017 = December 4, 2017
12-04-2017 = April 12, 2017

在上面的示例中,通过切换日期和月份,我们仍然可以获得有效日期,这可能会导致您的应用程序出现意外结果。要解决这些潜在问题,建议使用 DateTime::createFromFormat()解析日期广告返回 DateTime()对象,您可以从中 get a Unix Timestamp , convert the date into another format ,或使用它与其他 DateTime 对象进行比较。

// Parse US date format
$date1 = DateTime::createFromFormat('m/d/Y', '04/18/2017');

// Get Unix timestamp of 1493581268
$timestamp = $date1->getTimestamp();

// Parse European date format
$date2 = DateTime::createFromFormat('d-m-Y', ''18-04-2017);

// Get MySQL format (ISO-8601) of 2017-04-18
$mysqlDate = $date2->format('Y-m-d');

另请参阅:

<小时/>

对于您的具体情况,以下代码将起作用:

$date = $date1 = DateTime::createFromFormat('m/d/Y', '20/02/2000');
$D->query = $date->format('Y-m-d'); // 2000-02-20

关于php - URL 中的日期 dd/mm/yyyy,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43894793/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com