获取PHP中给定周数的第一周

Posted

技术标签:

【中文标题】获取PHP中给定周数的第一周【英文标题】:Get the first week day in a given week number in PHP 【发布时间】:2013-08-29 09:20:36 【问题描述】:

如何获取给定周数中的第一周? 我正在 php 中为日历应用程序创建一个函数。

想法:当我点击一个基本上使用 +1 个月的 strtotime 的链接时,它当然只会跳转到同一天。我需要正确的星期数。

示例:当我使用菜单从 8 月移动到 9 月时,它不应该选择我在 8 月的同一日期,而是选择 9 月第一周的第一天(星期一,9 月 2 日,星期36 号)。

从 9 月到 10 月:第 40 周,10 月 1 日星期二。

【问题讨论】:

你能写信质疑你的日期输出格式吗?你只有年份2013 和周数40 @Bora 是的。整个想法是日历应该检查哪一天是给定周数中的合法第一天。所以基本上,如果我想获取第 40 周的第一个工作日,它应该返回正确的工作日,而不是总是星期一:) 当然,这一年至关重要,因为每年的工作日并不总是相同的。 ISO 周总是从星期一开始。 2013 年第 40 周从 2013 年 9 月 30 日星期一开始。您如何定义“合法的第一天”? @CaptainPayalytic timeanddate.com/calendar 实际上,有星期四的那一周(或者换句话说:3 天中的 4 天)将决定它发生在哪个月。所以第 40 周不是从 9 月 30 日星期一开始,而是从 10 月 1 日(星期二)开始。至少这里(芬兰)是这样。日历如下所示:paivyri.fi。从那里你可以看到我的代码应该如何改变周数。 不,2013 年第 40 周从 9 月 30 日开始。那是对的。我知道你需要别的东西,但是 ISO 周从星期一开始,不管你喜欢与否。如果我理解你,如果周在 2 个不同的月份,你需要 first-next-date 吗? 【参考方案1】:

我找到了一个和你想要的完全一样的功能。这是setISODate

$date = new DateTime();
$date->setISODate(2013, 35, 1);
echo $date->format('Y-m-d');

您可以根据需要更改Y-m-d 日期格式

输出

2013-08-26 // This week number and monday

用法

setISODate(year, week, day)

【讨论】:

【参考方案2】:

试试这个代码

<?php
        $week = 3;
        $year = 2009;

        $timestamp = mktime( 0, 0, 0, 1, 1,  $year ) + ( $week * 7 * 24 * 60 * 60 );
        $timestamp_for_monday = $timestamp - 86400 * ( date( 'N', $timestamp ) - 1 );
        $date_for_monday = date( 'Y-m-d', $timestamp_for_monday );
?>

【讨论】:

【参考方案3】:

就像every1 已经说过的那样,ISO 周从星期一开始。来自http://en.wikipedia.org/wiki/ISO_week_date 的引用:Weeks start with Monday.

如果我正确理解您的问题,如果所选周在 2 个不同的月份中,您需要下个月的 first-next-date 吗?

function getFirstWeekDay($year, $week) 
    $dt = (new DateTime)->setISODate($year, $week, 1);
    $dtC = clone $dt;
    for ($N = $dt->format('N'); $N < 7; $N++) 
        $dtC->modify('+1 day');
        if ($dt->format('m') !== $dtC->format('m')) 
            return $dtC;
        
    
    return $dt;


echo getFirstWeekDay(2013, 40)->format('W\t\h \w\e\e\k \i\s Y-m-d'); 
# 40th week is 2013-10-01

echo getFirstWeekDay(2013, 1)->format('W\t\h \w\e\e\k \i\s Y-m-d'); 
# 1th week is 2013-01-01

【讨论】:

以上是关于获取PHP中给定周数的第一周的主要内容,如果未能解决你的问题,请参考以下文章

亚马逊 - Redshift:给定日期的周数错误

Teradata SQL 周数 - 从 1 月 1 日开始的第 1 周,周数与一周中的特定日期对齐

js-显示指定周数的周一和周日,指定月份的第一天和最后一天-----------个人百度 整理的

如何在Oracle中生成一周的第一天,一周的最后一天和两个日期之间的周数

python中的财政周数

如何计算当前日期是当年的第几周