Подтвердить что ты не робот

Как я могу получить текущий месяц и предыдущие три месяца, используя PHP

Кто-нибудь скажет мне, как получить текущий месяц и предыдущие три месяца, используя PHP

Например:

echo date("y:M:d");

вывод будет: 09: Oct: 20

Но мне нужно:

Август

сентябрь

Октябрь

в качестве вывода.

Спасибо заранее...

Феро

4b9b3361

Ответ 1

для полного текстового представления месяца вам нужно пройти "F":

echo date("y:F:d");

за предыдущий месяц вы можете использовать

echo date("y:F:d",strtotime("-1 Months"));

Ответ 2

Следите за FUAH! Другие ответы не удастся выполнить 31-го числа месяца. Используйте это вместо:

/*
Handles month/year increment calculations in a safe way,
avoiding the pitfall of 'fuzzy' month units.

Returns a DateTime object with incremented month values, and a date value == 1.
*/
function incrementDate($startDate, $monthIncrement = 0) {

    $startingTimeStamp = $startDate->getTimestamp();
    // Get the month value of the given date:
    $monthString = date('Y-m', $startingTimeStamp);
    // Create a date string corresponding to the 1st of the give month,
    // making it safe for monthly calculations:
    $safeDateString = "first day of $monthString";
    // Increment date by given month increments:
    $incrementedDateString = "$safeDateString $monthIncrement month";
    $newTimeStamp = strtotime($incrementedDateString);
    $newDate = DateTime::createFromFormat('U', $newTimeStamp);
    return $newDate;
}

$currentDate = new DateTime();
$oneMonthAgo = incrementDate($currentDate, -1);
$twoMonthsAgo = incrementDate($currentDate, -2);
$threeMonthsAgo = incrementDate($currentDate, -3);

echo "THIS: ".$currentDate->format('F Y') . "<br>";
echo "1 AGO: ".$oneMonthAgo->format('F Y') . "<br>";
echo "2 AGO: ".$twoMonthsAgo->format('F Y') . "<br>";
echo "3 AGO: ".$threeMonthsAgo->format('F Y') . "<br>";

Подробнее см. мой ответ здесь

Ответ 3

в этом месяце

date("y:M:d", mktime(0, 0, 0, date('m'), date('d'), date('Y')));

предыдущие месяцы

date("y:M:d", mktime(0, 0, 0, date('m') - 1, date('d'), date('Y')));
date("y:M:d", mktime(0, 0, 0, date('m') - 2, date('d'), date('Y')));

Ответ 4

Попробуйте использовать встроенную функцию strtotime в PHP и используя "F" для полного текстового вывода:

echo date('y:F:d'); // first month
echo date('y:F:d', strtotime('-1 month')); // previous month
echo date('y:F:d', strtotime('-2 month')); // second previous month
echo date('y:F:d', strtotime('-3 month')); // third previous month

Ответ 5

Если вы хотите быть ООПом, попробуйте следующее:

$dp=new DatePeriod(date_create(),DateInterval::createFromDateString('last month'),2);
foreach($dp as $dt) echo $dt->format("y:M:d"),"\n"; //or "y F d"

выходы:

  • 09: Октябрь: 20
  • 09: сентябрь: 20
  • 09: Август: 20

Ответ 6

Вам понадобится использовать дату ( "F" ); чтобы получить полное текстовое представление даты.

Ответ 7

DECLARE @STARTDATE INT

SET @STARTDATE = -12

WHILE @STARTDATE < 0

BEGIN

PRINT DATENAME(MONTH,DATEADD(MM,@STARTDATE,GETDATE()))+' '+ DATENAME(YEAR, DATEADD(MM,@STARTDATE ,GETDATE()))

SET @STARTDATE [email protected]+1

END

Ответ 8

echo date('F', strtotime('-2 month')), '<br>',
     date('F', strtotime('last month')), '<br>',
     date('F');

Ответ 9

DECLARE @STARTDATE VARCHAR(MAX)
DECLARE @ENDDATE VARCHAR(MAX)
DECLARE @A INT
SET @A=-12
SET @STARTDATE= DATENAME(MONTH,GETDATE())+ DATENAME(YEAR, DATEADD(MONTH,0,GETDATE()))
WHILE @A < 0
BEGIN 
SET @STARTDATE = DATENAME(MONTH,DATEADD(MONTH,@A,GETDATE()))+' '+ DATENAME(YEAR, DATEADD(MONTH,@A,GETDATE()))
SET @[email protected]+1
PRINT @STARTDATE
END