DateTime::Format::Natural man page on Alpinelinux

Man page or keyword search:  
man Server   18016 pages
apropos Keyword Search (all sections)
Output format
Alpinelinux logo
[printable version]

DateTime::Format::NatuUser3Contributed Perl DocumeDateTime::Format::Natural(3)

NAME
       DateTime::Format::Natural - Create machine readable date/time with
       natural parsing logic

SYNOPSIS
	use DateTime::Format::Natural;

	$parser = DateTime::Format::Natural->new;

	$date_string  = $parser->extract_datetime($extract_string);
	@date_strings = $parser->extract_datetime($extract_string);

	$dt = $parser->parse_datetime($date_string);
	@dt = $parser->parse_datetime_duration($date_string);

	if ($parser->success) {
	    # operate on $dt/@dt, for example:
	    printf("%02d.%02d.%4d %02d:%02d:%02d\n", $dt->day,
						     $dt->month,
						     $dt->year,
						     $dt->hour,
						     $dt->min,
						     $dt->sec);
	} else {
	    warn $parser->error;
	}

	@traces = $parser->trace;

DESCRIPTION
       "DateTime::Format::Natural" takes a string with a human readable
       date/time and creates a machine readable one by applying natural
       parsing logic.

CONSTRUCTOR
   new
       Creates a new "DateTime::Format::Natural" object. Arguments to "new()"
       are options and not necessarily required.

	$parser = DateTime::Format::Natural->new(
		  datetime	=> DateTime->new(...),
		  lang		=> 'en',
		  format	=> 'mm/dd/yy',
		  prefer_future => '[0|1]',
		  time_zone	=> 'floating',
		  daytime	=> { morning   => 06,
				     afternoon => 13,
				     evening   => 20,
				   },
	);

       ·   "datetime"

	   Overrides the present now with a DateTime object provided.

       ·   "lang"

	   Contains the language selected, currently limited to "en"
	   (english).  Defaults to '"en"'.

       ·   "format"

	   Specifies the format of numeric dates, defaults to '"d/m/y"'.

       ·   "prefer_future"

	   Turns ambiguous weekdays/months to their future relatives. Accepts
	   a boolean, defaults to false.

       ·   "time_zone"

	   The time zone to use when parsing and for output. Accepts any time
	   zone recognized by DateTime. Defaults to 'floating'.

       ·   "daytime"

	   An anonymous hash reference consisting of customized daytime hours,
	   which may be selectively changed.

METHODS
   parse_datetime
       Returns a DateTime object constructed from a human readable date/time
       string.

	$dt = $parser->parse_datetime($date_string);
	$dt = $parser->parse_datetime(string => $date_string);

       ·   "string"

	   The date string.

   parse_datetime_duration
       Returns one or two DateTime objects constructed from a human readable
       date/time string which may contain timespans/durations. Same interface
       and options as "parse_datetime()", but should be explicitly called in
       list context.

	@dt = $parser->parse_datetime_duration($date_string);
	@dt = $parser->parse_datetime_duration(string => $date_string);

   extract_datetime
       Returns parsable date/time substrings (also known as expressions)
       extracted from the string provided; in scalar context only the first
       parsable substring is returned, whereas in list context all parsable
       substrings are returned.	 Each extracted substring can then be passed
       to the "parse_datetime()"/ "parse_datetime_duration()" methods.

	$date_string  = $parser->extract_datetime($extract_string);
	@date_strings = $parser->extract_datetime($extract_string);
	# or
	$date_string  = $parser->extract_datetime(string => $extract_string);
	@date_strings = $parser->extract_datetime(string => $extract_string);

   success
       Returns a boolean indicating success or failure for parsing the
       date/time string given.

   error
       Returns the error message if the parsing did not succeed.

   trace
       Returns one or two strings with the grammar keyword for the valid
       expression parsed, traces of methods which were called within the Calc
       class and a summary how often certain units have been modified. More
       than one string is commonly returned for durations. Useful as a
       debugging aid.

GRAMMAR
       The grammar handling has been rewritten to be easily extendable and
       hence everybody is encouraged to propose sensible new additions and/or
       changes.

       See the classes "DateTime::Format::Natural::Lang::[language_code]" if
       you're intending to hack a bit on the grammar guts.

EXAMPLES
       See the classes "DateTime::Format::Natural::Lang::[language_code]" for
       an overview of currently valid input.

BUGS & CAVEATS
       "parse_datetime()"/"parse_datetime_duration()" always return one or two
       DateTime objects regardless whether the parse was successful or not. In
       case no valid expression was found or a failure occurred, an unaltered
       DateTime object with its initial values (most often the "current" now)
       is likely to be returned. It is therefore recommended to use
       "success()" to assert that the parse did succeed (at least, for common
       uses), otherwise the absence of a parse failure cannot be guaranteed.

       "parse_datetime()" is not capable of handling durations.

CREDITS
       Thanks to Tatsuhiko Miyagawa for the initial inspiration. See
       Miyagawa's journal entry <http://use.perl.org/~miyagawa/journal/31378>
       for more information.

       Furthermore, thanks to (in order of appearance) who have contributed
       valuable suggestions and patches:

	Clayton L. Scott
	Dave Rolsky
	CPAN Author 'SEKIMURA'
	mike (pulsation)
	Mark Stosberg
	Tuomas Jormola
	Cory Watson
	Urs Stotz
	Shawn M. Moore
	Andreas J. Koenig
	Chia-liang Kao
	Jonny Schulz
	Jesse Vincent
	Jason May
	Pat Kale
	Ankur Gupta
	Alex Bowley
	Elliot Shank
	Anirvan Chatterjee
	Michael Reddick
	Christian Brink
	Giovanni Pensa
	Andrew Sterling Hanenkamp
	Eric Wilhelm
	Kevin Field
	Wes Morgan
	Vladimir Marek
	Rod Taylor
	Tim Esselens
	Colm Dougan
	Chifung Fan
	Xiao Yafeng
	Roman Filippov

SEE ALSO
       dateparse, DateTime, Date::Calc, <http://datetime.perl.org>

AUTHOR
       Steven Schubiger <schubiger@cpan.org>

LICENSE
       This program is free software; you may redistribute it and/or modify it
       under the same terms as Perl itself.

       See <http://dev.perl.org/licenses/>

POD ERRORS
       Hey! The above document had some coding errors, which are explained
       below:

       Around line 802:
	   Non-ASCII character seen before =encoding in 'Koenig'. Assuming
	   ISO8859-1

perl v5.18.2			  2014-05-13	  DateTime::Format::Natural(3)
[top]

List of man pages available for Alpinelinux

Copyright (c) for man pages and the logo by the respective OS vendor.

For those who want to learn more, the polarhome community provides shell access and support.

[legal] [privacy] [GNU] [policy] [cookies] [netiquette] [sponsors] [FAQ]
Tweet
Polarhome, production since 1999.
Member of Polarhome portal.
Based on Fawad Halim's script.
....................................................................
Vote for polarhome
Free Shell Accounts :: the biggest list on the net