經常會有人被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...