solaries使用date獲取前一天日期,使用perl命令獲取歷史時間方法

neverinit發表於2018-10-26

1.Linux系統下獲取歷史日期的方法

獲取前一天日期:

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

獲取15天前日期:

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


2.solaries下執行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]

顯然不支援,不過可以格式化當前日期輸出

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

中國的時區是 +8 區,所以獲取 n 天前的時間方法為:

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

其中, X=24*n-8


但是對於時間過於長,如10天前,使用該方法返回的結果就不對:

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

經過測試,該方法可以獲取前一週內的時間。

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命令獲取歷史時間

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

該方法的原理是透過呼叫strftime函式,使用當前時間減去N天的秒數N*24*60*60,獲取當前時間或者往前N天的歷史時間。

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/31394774/viewspace-2217737/,如需轉載,請註明出處,否則將追究法律責任。

相關文章