Skip to main content

Find the dates ( month start and end dates) between the given two dates using PHP

When you want to pull the dates between two dates, where the between dates are connecting dots. If you want to list the complete date ranges through months. For example, to find the dates between below dates

date1 = '2022-12-29';
date2 = '2023-02-20';

expected output would be 


Start DateEnd Date
2022-12-292022-12-31
2023-01-012023-01-31
2023-02-012023-02-20
 

<?php

/*
 * Returns array of month's start & end dates between provided dates.
 *
 * @param string $start_date
 * @param string $end_date
 * 
 *
 * @return array
 */
 function getDates($start_date, $end_date){
    $start_date_obj = new DateTime($start_date);
    $end_date_obj = new DateTime($end_date);
    
    $diff = $end_date_obj->diff($start_date_obj);
    $months = (($diff->y) * 12) + ($diff->m);
    
    $dates[] = array('start_date' => $start_date, 'end_date' => date('Y-m-t', strtotime($start_date)), 'suffix' => date('Y-m', strtotime($start_date)));
    $new_start_date = strtotime(date('Y-m-01', strtotime($start_date)));
    for($i = 1; $i <= $months; $i++){ 
        $new_start_date = strtotime("+1 months", $new_start_date);
        $dates[] = array('start_date' => date('Y-m-01', $new_start_date), 'end_date' => date('Y-m-t', $new_start_date) , 'suffix' => date('Y-m', $new_start_date));
    }
    $dates[] = array('start_date' => date('Y-m-01', strtotime($end_date)), 'end_date' => $end_date, 'suffix' => date('Y-m', strtotime($end_date)));
    
    return $dates;
}

$start_date = '2022-12-29';
$end_date = '2023-02-20';
$dates = getDates($start_date, $end_date);
print_r($dates);
?>



Output:
Array
(
    [0] => Array
        (
            [start_date] => 2022-12-29
            [end_date] => 2022-12-31
            [Ym] => 2022-12
        )

    [1] => Array
        (
            [start_date] => 2023-01-01
            [end_date] => 2023-01-31
            [Ym] => 2023-01
        )

    [2] => Array
        (
            [start_date] => 2023-02-01
            [end_date] => 2023-02-20
            [Ym] => 2023-02
        )

)

Comments

Popular posts from this blog

Multiple Checkboxes Validation

This is a regular problem and solution is hardly available on google. When we use multiple checkboxes of same group (same name with square brackets) and you've to read the values from server side, then below solution will help you. Here I'm using jQuery (https://jquery.com/) and jQuery Validate plugin (https://jqueryvalidation.org/) For an example, I've to ask a user which of the listed book they are interested to know about <form id="BooksForm" method="post" name="BooksForm"> <p>Books you are interested in </p> <input class="Books" id="Book1" name="Books[]" type="checkbox" value="1" /> The Inner Game of Tennis <br /> <input class="Books" id="Book2" name="Books[]" type="checkbox" value="1" /> Monk who sold his ferrari <br /> <input class="Books" id="Book3" name=...

PHP Code Review Guidelines

General  The code works  The code is easy to understand  Follows coding conventions  Names are simple and if possible short  Names are spelt correctly  Names contain units where applicable  There are no usages of magic numbers  No hard coded constants that could possibly change in the future  All variables are in the smallest scope possible  There is no commented out code  There is no dead code (inaccessible at Runtime)  No code that can be replaced with library functions  Variables are not accidentally used with null values  Variables are immutable where possible  Code is not repeated or duplicated  There is an else block for every if clause even if it is empty  No complex/long boolean expressions  No negatively named boolean variables  No empty blocks of code  Ideal data structures are used  Constructors do not accept null/none values  Catch clause...

The 7 Types of Leadership: Inspiring Examples and Insights

Leadership is a multifaceted concept with various styles that cater to different needs and situations. Understanding these styles can help you develop your leadership skills and adapt to diverse scenarios. In this article, we'll explore seven prominent leadership styles, each accompanied by insightful examples from influential authors. Let's dive in! Type 1: Transformational Leadership 🚀 Transformational Leadership: Inspiring Change and Innovation Transformational leadership focuses on inspiring and motivating followers to achieve extraordinary outcomes and, in the process, develop their own leadership capacity. Example from Author: James MacGregor Burns James MacGregor Burns, in his book "Leadership," describes transformational leaders as those who seek to change the status quo by appealing to their followers' values and sense of higher purpose. 🔸 Characteristics: - Inspirational Motivation - Intellectual Stimulation - Individualized Consideration - Idealized I...