溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

solaries中怎么利用date獲取前一天日期

發(fā)布時(shí)間:2021-07-29 14:34:14 來源:億速云 閱讀:152 作者:Leah 欄目:建站服務(wù)器

solaries中怎么利用date獲取前一天日期,相信很多沒有經(jīng)驗(yàn)的人對此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個(gè)問題。

1.Linux系統(tǒng)下獲取歷史日期的方法

獲取前一天日期:

date -d last-day +%Y%m%d

獲取15天前日期:

date +%Y%m%d --date '15 days ago'

2.solaries下執(zhí)行Linux的date -d命令,行不通

oracle@cwgsdb1:~$ date -d last-day +%Y%m%d
date: illegal option -- d
usage:  date [-u] mmddHHMM[[cc]yy][.SS]
        date [-u] [+format]
        date -a [-]sss[.fff]

顯然不支持,不過可以格式化當(dāng)前日期輸出

oracle@cwgsdb1:~$ date +%Y%m%d
20181026

3.solaries下的date命令獲取前一天日期

oracle@cwgsdb1:~$ echo `TZ=$TZ date`
Friday, October 26, 2018 09:29:57 PM CST
oracle@cwgsdb1:~$ echo `TZ=$TZ+16 date`
Thursday, October 25, 2018 09:30:11 PM localtime
oracle@cwgsdb1:~$ date
Friday, October 26, 2018 09:31:00 PM CST
oracle@cwgsdb1:~$ echo `TZ=$TZ+24 date`
Thursday, October 25, 2018 01:31:55 PM localtime
oracle@cwgsdb1:~$ echo `TZ=$TZ+40 date`
Wednesday, October 24, 2018 09:31:59 PM localtime
oracle@cwgsdb1:~$ echo $TZ
localtime

中國的時(shí)區(qū)是+8區(qū),所以獲取n天前的時(shí)間方法為:

oldDate=`TZ=$TZ+X date +%Y%m%d`

其中,X=24*n-8

但是對于時(shí)間過于長,如10天前,使用該方法返回的結(jié)果就不對:

oracle@cwgsdb1:~$ echo `TZ=$TZ+232 date`
Friday, October 26, 2018 01:34:00 PM GMT

經(jīng)過測試,該方法可以獲取前一周內(nèi)的時(shí)間。

oracle@cwgsdb1:~$ echo `TZ=$TZ+112 date`
Sunday, October 21, 2018 09:35:08 PM localtime
oracle@cwgsdb1:~$ echo `TZ=$TZ+136 date`
Saturday, October 20, 2018 09:35:24 PM localtime
oracle@cwgsdb1:~$ echo `TZ=$TZ+160 date`
Friday, October 19, 2018 09:35:47 PM localtime
oracle@cwgsdb1:~$ echo `TZ=$TZ+184 date`
Friday, October 26, 2018 01:35:57 PM GMT

4.solaries下使用perl命令獲取歷史時(shí)間

oracle@cwgsdb1:~$ echo `perl -MPOSIX -le 'print strftime "%Y%m%d %H%M%S", localtime(time-15*24*60*60)'`
20181011 213937
oracle@cwgsdb1:~$ echo `perl -MPOSIX -le 'print strftime "%Y%m%d %H%M%S", localtime(time)'`
20181026 213951
oracle@cwgsdb1:~$ echo `perl -MPOSIX -le 'print strftime "%Y%m%d %H%M%S", localtime(time-30*24*60*60)'`
20180926 214011
oracle@cwgsdb1:~$ echo `perl -MPOSIX -le 'print strftime "%Y%m%d %H%M%S", localtime(time-40*24*60*60)'`
20180916 214016

該方法的原理是通過調(diào)用strftime函數(shù),使用當(dāng)前時(shí)間減去N天的秒數(shù)N*24*60*60,獲取當(dāng)前時(shí)間或者往前N天的歷史時(shí)間。

看完上述內(nèi)容,你們掌握solaries中怎么利用date獲取前一天日期的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI