解決strtotime增加減少乙個月日期不准的問題

2021-09-13 18:10:32 字數 1643 閱讀 2239

經常會有人被strtotime結合-1 month, +1 month, next month的時候搞得很困惑, 然後就會覺得這個函式有點不那麼靠譜, 動不動就出問題. 用的時候就會很慌…

這不, 剛剛就有人在微博上又問我:

鳥哥,今天是2018-07-31 執行**:

date("y-m-d",strtotime("-1 month"))

怎麼輸出是2018-07-01?

好的吧, 雖然這個問題看起來很迷惑, 但從內部邏輯上來說呢, 其實是」對」的, 你先別著急哈, 讓我慢慢講:

我們來模擬下date內部的對於這種事情的處理邏輯:

是不是邏輯很」清晰」呢? 我們也可以手動驗證第二個步驟, 比如:

var_dump(date("y-m-d", strtotime("2017-06-31")));

//輸出2017-07-01

也就是說, 只要涉及到大小月的最後一天, 都可能會有這個迷惑, 我們也可以很輕鬆的驗證類似的其他月份, 印證這個結論:

var_dump(date("y-m-d", strtotime("-1 month", strtotime("2017-03-31"))));

//輸出2017-03-03

var_dump(date("y-m-d", strtotime("+1 month", strtotime("2017-08-31"))));

//輸出2017-10-01

var_dump(date("y-m-d", strtotime("next month", strtotime("2017-01-31"))));

//輸出2017-03-03

var_dump(date("y-m-d", strtotime("last month", strtotime("2017-03-31"))));

//輸出2017-03-03

那怎麼辦呢?

從php5.3開始呢, date新增了一系列修正短語, 來明確這個問題, 那就是」first day of」 和 「last day of」, 也就是你可以限定好不要讓date自動」規範化」:

var_dump(date("y-m-d", strtotime("last day of -1 month", strtotime("2017-03-31"))));

//輸出2017-02-28

var_dump(date("y-m-d", strtotime("first day of +1 month", strtotime("2017-08-31"))));

輸出2017-09-01

var_dump(date("y-m-d", strtotime("first day of next month", strtotime("2017-01-31"))));

輸出2017-02-01

var_dump(date("y-m-d", strtotime("last day of last month", strtotime("2017-03-31"))));

輸出2017-02-28

那如果是5.3之前的版本(還有人用麼?), 你可以使用mktime之類的, 把所有的日子忽略掉, 比如都限定為每月1號就可以了, 只不過就不如直接用first day來的更加優雅.

現在, 搞清楚了內部原理, 是不是就不慌了?

無損分割槽,增加減少c盤容量

2011 08 08 21 20 284人閱讀 收藏 舉報 由於c盤容量不夠了,又不想重啟。因為一重啟很多軟體就要重新註冊,為了省麻煩。找到一款叫acronis disk director suite的軟體,順利地擴充套件了c盤,而且資料沒有任何丟失,操作也很方便。和我有同樣困擾的同學可以參照下面的...

sql跳過休息日增加 減少時間

oracle 給出開始時間和增 減的時間,求出跳過休息日的結束時間。例 已知2020年9 10月日曆 若開始時間為2020 10 09,增加1天,則結束時間應為2020 10 09 若開始時間為2020 10 09,增加2天,則結束時間應為2020 10 10 若開始時間為2020 10 01,增加...

c 實現電腦系統音量的增加,減少,靜音等。

網上 的內容不知道正確與否待本人驗證後,給予測試結果!1 using system.runtime.interopservices 2public partial class form1 form315 1617 private void button1 click object sender,ev...