#!/usr/bin/perl -w # # calcweek.pl - Calculate the week number from any given date, # or the default, if no date is given. # # Sander Venema version 20080819 use strict; use Getopt::Long; use Pod::Usage; use Data::Dumper; use Date::ISO; use POSIX qw(strftime); # set some defaults my $verbose = 0; my $date = strftime("%Y%m%d", localtime); # fetch options Getopt::Long::Configure(qw(no_ignore_case bundling)); GetOptions( 'h|help' => sub { pod2usage({-verbose => 1, -input => \*DATA}); exit; }, 'H|man' => sub { pod2usage({-verbose => 2, -input => \*DATA}); exit; }, 'v|verbose' => \$verbose, 'd|date=i' => \$date, ) or pod2usage(2); # convert date string to Date::ISO object and calculate the # year, week and number of the day (starting with Monday) my $iso = Date::ISO->new(iso => $date); my ($year, $week, $week_day) = ($iso->year, $iso->iso_week, $iso->iso_week_day); # print everything, depending on level of $verbose print "$year-W$week-$week_day\n" if $verbose; print "$week\n" if !$verbose; __DATA__ =head1 NAME calcweek.pl - Calculate the week number from any given date =head1 SYNOPSIS calcweek.pl [-h] [-H] [-v] [-d yyyymmdd] =head1 DESCRIPTION This is a small Perl script to calculate the number of the week from any given date, (given in the ISO 8601 format), or uses today's date if no date is specified. It was written just to scratch an itch I had in the past, when I frequently needed to know the number of the week for planning purposes. The program returns the number of the week it is, and if verbose is turned on, it will print the year, weeknumber, and day of the week in ISO 8601 format (YYYY-Www-D). When verbose is turned off, it will only output the number of the week. The following options are available: -h --help Display this help -H --man Display detailed help (manpage) -v --verbose Turn more verbose messages on -d --date Set the date to calculate (default: today) =head1 DEPENDENCIES Date::ISO, POSIX, Getopt::Long, Pod::Usage, Data::Dumper =head1 SEE ALSO For more information about ISO 8601: http://www.iso.org/iso/date_and_time_format =head1 BUGS Lots. Probably. Any help on how to improve it is appreciated. :-) =head1 AUTHOR Sander Venema