The London Perl and Raku Workshop takes place on 26th Oct 2024. If your company depends on Perl, please consider sponsoring and/or attending.

NAME

Date::WeekNumber - calculate week of the year (ISO 8601 weeks, or 'CPAN weeks')

SYNOPSIS

 use Date::WeekNumber qw/ cpan_week_number /;
 
 $week = cpan_week_number('2013-12-31'); # '2014-W01'
 $week = cpan_week_number(time());
 $week = cpan_week_number({ year => 2012, month => 12, day => 31});

Or to get weeks according to ISO 8601:

 use Date::WeekNumber qw/ iso_week_number /;
 
 # pass parameters as for cpan_week_number() above

DESCRIPTION

The two functions provided by this module can be used to generate the week number in the year of a given date. For example:

 print "Today is in week ", iso_week_number(time()), "\n";

Which at the time I'm writing this will print:

 Today is in week 2014-W09

There are two functions provided: iso_week_number() returns the week number according to ISO 8601, where the weeks run from Monday through Sunday, and cpan_week_number(), where the weeks run from Sunday through Saturday. A more complete definition of the week naming schemes is given below.

The CPAN week number is the definition used by Chris Madsen's CPAN once a week, every week contest, and my CPAN Regulars Releasers page.

There are a number of modules that can be used to calculate the week number, but I wanted a minimalist interface that returned a string format, rather than the year and week number separately. Plus I sometimes have an epoch and sometimes a date string, so I decided to experiment with a DWIMish interface (Do What I Mean), where you could pass the date in whatever format you have it available, and it'll be handled.

Week numbering scheme

iso_week_number

The iso_week_number() function returns a string with the week number according to ISO 8601.

ISO 8601 defines week 01 as being the week with the first Thursday in it. The first day of the week is Monday. Consider the transition from 2013 to 2014:

    December 2013            January 2014
 Su Mo Tu We Th Fr Sa    Su Mo Tu We Th Fr Sa
  1  2  3  4  5  6  7              1  2  3  4
  8  9 10 11 12 13 14     5  6  7  8  9 10 11
 15 16 17 18 19 20 21    12 13 14 15 16 17 18
 22 23 24 25 26 27 28    19 20 21 22 23 24 25
 29 30 31                26 27 28 29 30 31

So 2014-W01 runs from 30th December 2013 to 5th January 2014.

Similarly, consider the transition from 2009 to 2010:

    December 2009        January 2010
 Su Mo Tu We Th Fr Sa    Su Mo Tu We Th Fr Sa
        1  2  3  4  5                    1  2
  6  7  8  9 10 11 12     3  4  5  6  7  8  9
 13 14 15 16 17 18 19    10 11 12 13 14 15 16
 20 21 22 23 24 25 26    17 18 19 20 21 22 23
 27 28 29 30 31          24 25 26 27 28 29 30
                         31

In this case 2009-W52 runs runs 28th December 2009 through 3rd January 2010, and 2010-W01 starts on Monday 4th January 2010.

cpan_week_number

The cpan_week_number() function returns a string with the week number according to 'CPAN Weeks'.

CPAN Weeks run from Sunday to Saturday, with week 01 of the year being the week containing the first Sunday in January. Consider the transition from 2011 to 2012:

    December 2011            January 2012
 Su Mo Tu We Th Fr Sa    Su Mo Tu We Th Fr Sa
              1  2  3     1  2  3  4  5  6  7
  4  5  6  7  8  9 10     8  9 10 11 12 13 14
 11 12 13 14 15 16 17    15 16 17 18 19 20 21
 18 19 20 21 22 23 24    22 23 24 25 26 27 28
 25 26 27 28 29 30 31    29 30 31

Week 2012-W01 runs from Sunday 1st January to Saturday 7th January.

Now look at the transition from 2006 to 2007:

    December 2006            January 2007
 Su Mo Tu We Th Fr Sa    Su Mo Tu We Th Fr Sa
                 1  2        1  2  3  4  5  6
  3  4  5  6  7  8  9     7  8  9 10 11 12 13
 10 11 12 13 14 15 16    14 15 16 17 18 19 20
 17 18 19 20 21 22 23    21 22 23 24 25 26 27
 24 25 26 27 28 29 30    28 29 30 31
 31

Week 2006-W53 runs from Sunday 31st December 2006 to Saturday 6th January 2007, and 2007-W01 runs from Sunday 7th January to Saturday 13th January.

SEE ALSO

Date::WeekOfYear provides a WeekOfYear() function, which returns the week number and associated year. As of version 1.05 this return the ISO 8601 week number, prior to that it returned something slightly different; you can still request the old week numbering scheme. Version 1.06 provided a mode for giving the output in the same format as this module.

POSIX contains the strftime() function, which is used by Date::WeekNumber.

DateTime provides a week() method, which returns the ISO week number and associated year for a DateTime instance. It also provides strftime().

Date::Calc provides Week_of_Year(), which returns the ISO week number and associated year.

Date::Manip provides a function Date_WeekOfYear which returns a week number between 0 and 53. Zero means it's a week in the previous year, and 53 may be in the following year.

Date::ISO8601 provides a number of functions for converting dates according to ISO 8601.

Date::ISO can be used to produce an ISO week number, using the iso_year() and iso_week() methods.

REPOSITORY

https://github.com/neilb/Date-WeekNumber

AUTHOR

Neil Bowers <neilb@cpan.org>

LICENSE AND COPYRIGHT

This software is copyright (c) 2014 by Neil Bowers <neilb@cpan.org>.

This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.