DateTime::getLastErrors

date_get_last_errors

(PHP 5 >= 5.3.0, PHP 7)

DateTime::getLastErrors -- date_get_last_errorsReturns the warnings and errors

설명

객체 기반 형식

public static array DateTime::getLastErrors ( void )

절차식 형식

array date_get_last_errors ( void )

Returns an array of warnings and errors found while parsing a date/time string.

인수

이 함수는 인수가 없습니다.

반환값

Returns array containing info about warnings and errors.

예제

Example #1 DateTime::getLastErrors() example

객체 기반 형식

<?php
try {
    
$date = new DateTime('asdfasdf');
} catch (
Exception $e) {
    
// For demonstration purposes only...
    
print_r(DateTime::getLastErrors());

    
// The real object oriented way to do this is
    // echo $e->getMessage();
}
?>

절차식 형식

<?php
$date 
date_create('asdfasdf');
print_r(date_get_last_errors());
?>

위 예제들의 출력:

Array
(
   [warning_count] => 1
   [warnings] => Array
       (
           [6] => Double timezone specification
       )

   [error_count] => 1
   [errors] => Array
       (
           [0] => The timezone could not be found in the database
       )

)

The indexes 6, and 0 in the example output refer to the character index in the string where the error occurred.

add a note add a note

User Contributed Notes 1 note

up
23
framework at photon-project dot com
13 years ago
DateTime::createFromFormat is smart to handle the cases where you input an invalid date, like April 31st, and convert it to May 1st. In some cases, you do not want this automatic smart handling of the dates for example in a user input form where you want to be sure that your user did input the date he wanted. To do that, you need to get access to the warnings, this method is the only way to do it:

<?php
$date
= DateTime::createFromFormat('Y-m-d', '1999-04-31');
print
$date->format('Y-m-d') . PHP_EOL;
print_r(DateTime::getLastErrors());
?>

The output is:

1999-05-01
Array
(
    [warning_count] => 1
    [warnings] => Array
        (
            [10] => The parsed date was invalid
        )

    [error_count] => 0
    [errors] => Array
        (
        )

)

So, here you can see, you have a warning because the date was invalid, but not an error because PHP was smart enough to convert it into a valid date. It is then up to you to do something with this information.
To Top