使用 php 查找月份中的特定星期

Posted

技术标签:

【中文标题】使用 php 查找月份中的特定星期【英文标题】:find specific weeks in month using php 【发布时间】:2014-03-11 14:17:02 【问题描述】:

我想从同月的星期一开始到星期天结束的月份中获取星期。 我会提供月份和年份。 例如:

$month = '03';
$year = '2014';

然后函数应该返回 2014-03-03 to 2014-03-09 作为月份的开始日期,因为该月的第一个星期一是 3 号。 然后继续一个月直到上周。 2014 年 3 月,第 31 日从星期一开始,但不会在 3 月结束,它会在 2014 年 6 月 4 日结束,因此不应计入。

现在,当我将月份传递为“04”时,该月份的第一周应计为 3 月 31 日。

我希望我说清楚,对不起语言。 到目前为止我已经尝试过:

$month = "04";
$year = "2014";
$beg = (int)date('W', strtotime("first day of $year-$month"));
$end = (int)date('W', strtotime("last day of $year-$month"));
$weeks = range($beg, $end);

foreach($weeks as $week) 
    $result = $this->getStartAndEndDate($week, $year);
    print_r($result);


function getStartAndEndDate($week, $year)

    $time = strtotime("1 January $year", time());
    $day = date('w', $time);
    $time += ((7*$week)+1-$day)*24*3600;
    $return[0] = date('Y-m-d', $time);
    $time += 6*24*3600;
    $return[1] = date('Y-m-d', $time);
    return $return;

输出:

Array
(
    [0] => 2014-03-03
    [1] => 2014-03-09
)
Array
(
    [0] => 2014-03-10
    [1] => 2014-03-16
)
Array
(
    [0] => 2014-03-17
    [1] => 2014-03-23
)
Array
(
    [0] => 2014-03-24
    [1] => 2014-03-30
)
Array
(
    [0] => 2014-03-31
    [1] => 2014-04-06
)
Array
(
    [0] => 2014-04-07
    [1] => 2014-04-13
)

【问题讨论】:

为什么它在一种情况下应该来自 31.03。在另一个不是从 24.02 开始。 (一周于 02.03 结束。) - 那么你究竟是如何解决“重叠月份”的?另外,您当前的代码在哪里让您失望? @kingkero 没错,它不仅仅是一个案例,它只是一个例子...... 在上面的输出中,我不想要最后两个数组。也 2014-03-31 应计入 2014 年 4 月(04) 【参考方案1】:

您可以为此使用DateTime 类:

$dt = new DateTime('1st march');

// is this a monday?
if($dt->format('N') !== '1') 
  // if not, went to next monday
  $dt->modify('next monday');


echo $dt->format('Y-m-d')
    . ' to ' . $dt->modify('next sunday')->format('Y-m-d');

输出:

2014-03-03 to 2014-03-09

【讨论】:

【参考方案2】:
<?php
function get_weeks($month, $year) 
    $weeks = array();

    $date = DateTime::createFromFormat('mY', $month.$year);
    $date->modify('first Monday of this month');

    $end = clone $date;
    $end->modify('last Monday of this month');
    $interval = DateInterval::createFromDateString('1 week');
    $period = new DatePeriod($date, $interval, $end);

    $counter = 1;
    foreach ($period as $dt) 
        $end_of_week = clone $dt;
        $end_of_week->modify('next Sunday');
        $weeks[] = sprintf("Week %u: %s - %s", 
            $counter,
            $dt->format('Y-m-d'),
            $end_of_week->format('Y-m-d')
        );      
        $counter++;
    

    return $weeks;

$weeks = get_weeks('03', '2014');
print_r($weeks);

Array
(
    [0] => Week 1: 2014-03-03 - 2014-03-09
    [1] => Week 2: 2014-03-10 - 2014-03-16
    [2] => Week 3: 2014-03-17 - 2014-03-23
    [3] => Week 4: 2014-03-24 - 2014-03-30
)

See it in action

【讨论】:

以上是关于使用 php 查找月份中的特定星期的主要内容,如果未能解决你的问题,请参考以下文章

PHP 使用Symfony插件sfDoctrineGuard按组名查找特定组中的用户

Oracle SQL:查找指定日期前 7 天的日期,不包括星期日和其他特定日期

如何获取特定月份的每个星期四或一周中的其他日期的日期?

使用 PHP 在存档中查找特定文件

查找前一周的最后一天

如何从sql中经过的天数中查找年份和月份