Intereting Posts

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

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

Например:

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

выход будет: 09: Окт: 20

Но мне нужно:

августейший

сентябрь

октября

как Выход.

Заранее спасибо…

Феро

для полного текстового представления месяца вам необходимо передать «F»:

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

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

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

Следите за 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>"; 

Более подробно см. Мой ответ здесь

этот месяц

 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'))); 

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

 $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

Попробуйте использовать встроенную функцию 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 

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

 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 =@STARTDATE+1 END 
 echo date('F', strtotime('-2 month')), '<br>', date('F', strtotime('last month')), '<br>', date('F'); 
 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 @A=@A+1 PRINT @STARTDATE END