Provided by: libdatetime-format-flexible-perl_0.34-1_all
NAME
DateTime::Format::Flexible - DateTime::Format::Flexible - Flexibly parse strings and turn them into DateTime objects.
SYNOPSIS
use DateTime::Format::Flexible; my $dt = DateTime::Format::Flexible->parse_datetime( 'January 8, 1999' ); # $dt = a DateTime object set at 1999-01-08T00:00:00
DESCRIPTION
If you have ever had to use a program that made you type in the date a certain way and thought "Why can't the computer just figure out what date I wanted?", this module is for you. DateTime::Format::Flexible attempts to take any string you give it and parse it into a DateTime object.
USAGE
This module uses DateTime::Format::Builder under the covers. parse_datetime Give it a string and it attempts to parse it and return a DateTime object. If it cannot it will throw an exception. my $dt = DateTime::Format::Flexible->parse_datetime( $date ); my $dt = DateTime::Format::Flexible->parse_datetime( $date, strip => [qr{\.\z}], # optional, remove a trailing period tz_map => {EDT => 'America/New_York'}, # optional, map the EDT timezone to America/New_York lang => ['es'], # optional, only parse using spanish european => 1, # optional, catch some cases of DD-MM-YY ); • "base" (optional) Does the same thing as the method "base". Sets a base datetime for incomplete dates. Requires a valid DateTime object as an argument. example: my $base_dt = DateTime->new( year => 2005, month => 2, day => 1 ); my $dt = DateTime::Format::Flexible->parse_datetime( '18 Mar', base => $base_dt, ); # $dt is now 2005-03-18T00:00:00 • "strip" (optional) Remove a substring from the string you are trying to parse. You can pass multiple regexes in an arrayref. example: my $dt = DateTime::Format::Flexible->parse_datetime( '2011-04-26 00:00:00 (registry time)', strip => [qr{\(registry time\)\z}], ); # $dt is now 2011-04-26T00:00:00 This is helpful if you have a load of dates you want to normalize and you know of some weird formatting beforehand. • "tz_map" (optional) Map a given timezone to another recognized timezone Values are given as a hashref. example: my $dt = DateTime::Format::Flexible->parse_datetime( '25-Jun-2009 EDT', tz_map => {EDT => 'America/New_York'}, ); # $dt is now 2009-06-25T00:00:00 with a timezone of America/New_York This is helpful if you have a load of dates that have timezones that are not recognized by DateTime::Timezone. • "lang" (optional) Specify the language map plugins to use. When DateTime::Format::Flexible parses a date with a string in it, it will search for a way to convert that string to a number. By default it will search through all the language plugins to search for a match. NOTE: as of 0.22, it will only do this search if it detects a string in the given date. Setting "lang" this lets you limit the scope of the search. example: my $dt = DateTime::Format::Flexible->parse_datetime( 'Wed, Jun 10, 2009', lang => ['en'], ); # $dt is now 2009-06-10T00:00:00 Currently supported languages are english (en), spanish (es) and german (de). Contributions, corrections, requests and examples are VERY welcome. See the DateTime::Format::Flexible::lang::en, DateTime::Format::Flexible::lang::es, and DateTime::Format::Flexible::lang::de for examples of the plugins. • "european" (optional) If european is set to a true value, an attempt will be made to parse as a DD-MM-YYYY date instead of the default MM-DD-YYYY. There is a chance that this will not do the right thing due to ambiguity. example: my $dt = DateTime::Format::Flexible->parse_datetime( '16/06/2010' , european => 1, ); # $dt is now 2010-06-16T00:00:00 • "MMYY" (optional) By default, this module will parse 12/10 as December 10th of the current year (MM/DD). If you want it to parse this as MM/YY instead, you can enable the "MMYY" option. example: my $dt = DateTime::Format::Flexible->parse_datetime('12/10'); # $dt is now [current year]-12-10T00:00:00 my $dt = DateTime::Format::Flexible->parse_datetime( '12/10', MMYY => 1, ); # $dt is now 2010-12-01T00:00:00 This is useful if you know you are going to be parsing a credit card expiration date. base gets/sets the base DateTime for incomplete dates. Requires a valid DateTime object as an argument when setting. This defaults to DateTime->now. example: DateTime::Format::Flexible->base( DateTime->new( year => 2009, month => 6, day => 22 )); my $dt = DateTime::Format::Flexible->parse_datetime( '23:59' ); # $dt is now 2009-06-22T23:59:00 build an alias for parse_datetime Example formats A small list of supported formats: YYYYMMDDTHHMMSS YYYYMMDDTHHMM YYYYMMDDTHH YYYYMMDD YYYYMM MM-DD-YYYY MM-D-YYYY MM-DD-YY M-DD-YY YYYY/DD/MM YYYY/M/DD YYYY/MM/D M-D MM-D M-D-Y Month D, YYYY Mon D, YYYY Mon D, YYYY HH:MM:SS ... thousands more there are 9000+ variations that are detected correctly in the test files (see t/data/* for most of them). If you can think of any that I do not cover, please let me know.
NOTES
As of version 0.11 you will get a DateTime::Infinite::Future object if the passed in date is 'infinity' and a DateTime::Infinite::Past object if the passed in date is '-infinity'. If you are expecting these types of strings, you might want to check for 'is_infinite()' from the object returned. example: my $dt = DateTime::Format::Flexible->parse_datetime( 'infinity' ); if ( $dt->is_infinite ) { # you have a Infinite object. }
BUGS/LIMITATIONS
You cannot use a 1 or 2 digit year as the first field unless the year is > 31: YY-MM-DD # not supported if YY is <= 31 Y-MM-DD # not supported It gets confused with MM-DD-YY
AUTHOR
Tom Heady <cpan@punch.net>
COPYRIGHT & LICENSE
Copyright 2007-2018 Tom Heady. This program is free software; you can redistribute it and/or modify it under the terms of either: • the GNU General Public License as published by the Free Software Foundation; either version 1, or (at your option) any later version, or • the Artistic License.
SEE ALSO
DateTime::Format::Builder, DateTime::Timezone, DateTime::Format::Natural