Writing Date-Processing Utilities
Problem
There’s a given date-processing operation that you need to perform frequently, so you want to write a utility that does it for you.
Solution
The utilities in this recipe provide some examples that show how to do that.
Discussion
Due to the idiosyncratic nature of dates, you might find it necessary to write date converters from time to time. This section shows some sample converters that serve various purposes:
isoize_date.pl reads a file looking for dates in U.S. format (
MM-DD-YY
) and converts them to ISO format.cvt_date.pl converts dates to and from any of ISO, U.S., or British formats. It is more general than isoize_date.pl, but requires that you tell it what kind of input to expect and what kind of output to produce.
monddccyy_to_iso.pl looks for dates like
Feb.
6
,1788
and converts them to ISO format. It illustrates how to map dates with nonnumeric parts to a format that MySQL will understand.
All three scripts are located in the transfer directory of the recipes
distribution. They assume datafiles
are in tab-delimited, linefeed-terminated format. (Use cvt_file.pl first if you need to work with
files that have a different format.)
Our first date-processing utility, isoize_date.pl, looks for dates in U.S. format and rewrites them into ISO format. You’ll recognize that it’s modeled after the general input-processing loop shown in Validating and Transforming Data, with some extra stuff thrown in to perform a specific type of conversion:
#!/usr/bin/perl ...
Get MySQL Cookbook, 2nd Edition now with the O’Reilly learning platform.
O’Reilly members experience books, live events, courses curated by job role, and more from O’Reilly and nearly 200 top publishers.