DateTime::Format::Strptime(3pm) - phpMan

Command: man perldoc info search(apropos)  


DateTime::Format::Strptime(3)  User Contributed Perl Documentation  DateTime::Format::Strptime(3)



NAME
       DateTime::Format::Strptime - Parse and format strp and strf time patterns

VERSION
       version 1.54

SYNOPSIS
           use DateTime::Format::Strptime;

           my $strp = DateTime::Format::Strptime->new(
               pattern   => '%T',
               locale    => 'en_AU',
               time_zone => 'Australia/Melbourne',
           );

           my $dt = $strp->parse_datetime('23:16:42');

           $strp->format_datetime($dt);

           # 23:16:42

           # Croak when things go wrong:
           my $strp = DateTime::Format::Strptime->new(
               pattern   => '%T',
               locale    => 'en_AU',
               time_zone => 'Australia/Melbourne',
               on_error  => 'croak',
           );

           $newpattern = $strp->pattern('%Q');

           # Unidentified token in pattern: %Q in %Q at line 34 of script.pl

           # Do something else when things go wrong:
           my $strp = DateTime::Format::Strptime->new(
               pattern   => '%T',
               locale    => 'en_AU',
               time_zone => 'Australia/Melbourne',
               on_error  => \&phone_police,
           );

DESCRIPTION
       This module implements most of strptime(3), the POSIX function that is the reverse of
       strftime(3), for "DateTime". While "strftime" takes a "DateTime" and a pattern and returns
       a string, "strptime" takes a string and a pattern and returns the "DateTime" object
       associated.

CONSTRUCTOR
       o   new( pattern => $strptime_pattern )

           Creates the format object. You must specify a pattern, you can also specify a
           "time_zone" and a "locale". If you specify a time zone then any resulting "DateTime"
           object will be in that time zone. If you do not specify a "time_zone" parameter, but
           there is a time zone in the string you pass to "parse_datetime", then the resulting
           "DateTime" will use that time zone.

           You can optionally use an on_error parameter. This parameter has three valid options:

           o   'undef'

               (not undef, 'undef', it's a string not an undefined value)

               This is the default behavior. The module will return undef whenever it gets upset.
               The error can be accessed using the "$object->errmsg" method.  This is the ideal
               behaviour for interactive use where a user might provide an illegal pattern or a
               date that doesn't match the pattern.

           o   'croak'

               (not croak, 'croak', it's a string, not a function)

               This used to be the default behaviour. The module will croak with an error message
               whenever it gets upset.

           o   sub{...} or \&subname

               When given a code ref, the module will call that sub when it gets upset.  The sub
               receives two parameters: the object and the error message. Using these two it is
               possible to emulate the 'undef' behavior. (Returning a true value causes the
               method to return undef. Returning a false value causes the method to bravely
               continue):

                   sub { $_[0]->{errmsg} = $_[1]; 1 },

METHODS
       This class offers the following methods.

       o   parse_datetime($string)

           Given a string in the pattern specified in the constructor, this method will return a
           new "DateTime" object.

           If given a string that doesn't match the pattern, the formatter will croak or return
           undef, depending on the setting of on_error in the constructor.

       o   format_datetime($datetime)

           Given a "DateTime" object, this methods returns a string formatted in the object's
           format. This method is synonymous with "DateTime"'s strftime method.

       o   locale($locale)

           When given a locale or "DateTime::Locale" object, this method sets its locale
           appropriately. If the locale is not understood, the method will croak or return undef
           (depending on the setting of on_error in the constructor)

           If successful this method returns the current locale. (After processing as above).

       o   pattern($strptime_pattern)

           When given a pattern, this method sets the object's pattern. If the pattern is
           invalid, the method will croak or return undef (depending on the value of the
           "on_error" parameter)

           If successful this method returns the current pattern. (After processing as above)

       o   time_zone($time_zone)

           When given a name, offset or "DateTime::TimeZone" object, this method sets the
           object's time zone. This effects the "DateTime" object returned by parse_datetime

           If the time zone is invalid, the method will croak or return undef (depending on the
           value of the "on_error" parameter)

           If successful this method returns the current time zone. (After processing as above)

       o   errmsg

           If the on_error behavior of the object is 'undef', error messages with this method so
           you can work out why things went wrong.

           This code emulates a $DateTime::Format::Strptime with the "on_error" parameter equal
           to 'croak':

           "$strp->pattern($pattern) or die $DateTime::Format::Strptime::errmsg"

EXPORTS
       There are no methods exported by default, however the following are available:

       o   strptime( $strptime_pattern, $string )

           Given a pattern and a string this function will return a new "DateTime" object.

       o   strftime( $strftime_pattern, $datetime )

           Given a pattern and a "DateTime" object this function will return a formatted string.

STRPTIME PATTERN TOKENS
       The following tokens are allowed in the pattern string for strptime (parse_datetime):

       o   %%

           The % character.

       o   %a or %A

           The weekday name according to the current locale, in abbreviated form or the full
           name.

       o   %b or %B or %h

           The month name according to the current locale, in abbreviated form or the full name.

       o   %C

           The century number (0-99).

       o   %d or %e

           The day of month (01-31). This will parse single digit numbers as well.

       o   %D

           Equivalent to %m/%d/%y. (This is the American style date, very confusing to non-
           Americans, especially since %d/%m/%y is    widely used in Europe.  The ISO 8601
           standard pattern is %F.)

       o   %F

           Equivalent to %Y-%m-%d. (This is the ISO style date)

       o   %g

           The year corresponding to the ISO week number, but without the century (0-99).

       o   %G

           The year corresponding to the ISO week number.

       o   %H

           The hour (00-23). This will parse single digit numbers as well.

       o   %I

           The hour on a 12-hour clock (1-12).

       o   %j

           The day number in the year (1-366).

       o   %m

           The month number (01-12). This will parse single digit numbers as well.

       o   %M

           The minute (00-59). This will parse single digit numbers as well.

       o   %n

           Arbitrary whitespace.

       o   %N

           Nanoseconds. For other sub-second values use "%[number]N".

       o   %p

           The equivalent of AM or PM according to the locale in use. (See DateTime::Locale)

       o   %r

           Equivalent to %I:%M:%S %p.

       o   %R

           Equivalent to %H:%M.

       o   %s

           Number of seconds since the Epoch.

       o   %S

           The second (0-60; 60 may occur for leap seconds. See DateTime::LeapSecond).

       o   %t

           Arbitrary whitespace.

       o   %T

           Equivalent to %H:%M:%S.

       o   %U

           The week number with Sunday the first day of the week (0-53). The first Sunday of
           January is the first day of week 1.

       o   %u

           The weekday number (1-7) with Monday = 1. This is the "DateTime" standard.

       o   %w

           The weekday number (0-6) with Sunday = 0.

       o   %W

           The week number with Monday the first day of the week (0-53). The first Monday of
           January is the first day of week 1.

       o   %y

           The year within century (0-99). When a century is not otherwise specified (with a
           value for %C), values in the range 69-99 refer to years in the twentieth century
           (1969-1999); values in the range 00-68 refer to years in the twenty-first century
           (2000-2068).

       o   %Y

           The year, including century (for example, 1991).

       o   %z

           An RFC-822/ISO 8601 standard time zone specification. (For example +1100) [See note
           below]

       o   %Z

           The timezone name. (For example EST -- which is ambiguous) [See note below]

       o   %O

           This extended token allows the use of Olson Time Zone names to appear in parsed
           strings. NOTE: This pattern cannot be passed to "DateTime"'s "strftime()" method, but
           can be passed to "format_datetime()".

AUTHOR EMERITUS
       This module was created by Rick Measham.

BUGS
       Please report any bugs or feature requests to "bug-datetime-format-strptime AT rt.org",
       or through the web interface at <http://rt.cpan.org>. I will be notified, and then you'll
       automatically be notified of progress on your bug as I make changes.

SEE ALSO
       "datetime AT perl.org" mailing list.

       http://datetime.perl.org/

       perl, DateTime, DateTime::TimeZone, DateTime::Locale

AUTHORS
       o   Dave Rolsky <autarch AT urth.org>

       o   Rick Measham <rickm AT cpan.org>

COPYRIGHT AND LICENSE
       This software is Copyright (c) 2013 by Dave Rolsky.

       This is free software, licensed under:

         The Artistic License 2.0 (GPL Compatible)



perl v5.16.3                                2013-04-03              DateTime::Format::Strptime(3)

Generated by $Id: phpMan.php,v 4.55 2007/09/05 04:42:51 chedong Exp $ Author: Che Dong
On Apache
Under GNU General Public License
2024-04-26 04:44 @3.145.183.137 CrawledBy Mozilla/5.0 AppleWebKit/537.36 (KHTML, like Gecko; compatible; ClaudeBot/1.0; +claudebot@anthropic.com)
Valid XHTML 1.0!Valid CSS!