web-dev-qa-db-ja.com

UNIXシェルで、昨日の日付を変数に取得する方法は?

現在の日付を変数「dt」に保存するために以下を行うシェルスクリプトがあります。

date "+%a %d/%m/%Y" | read dt
echo ${dt}

昨日日付を変数に取得するにはどうすればよいですか?

基本的に私が達成しようとしているのは、ログの各行に「Mon 01/02/2010」形式の日付が含まれているため、grepを使用して昨日のすべての行をログファイルからプルすることです。

どうもありがとう

37
Chris

Perlを使用できる場合(およびdateyesterdayなどの素敵な機能がない場合)、次を使用できます。

pax> date
Thu Aug 18 19:29:49 XYZ 2010

pax> dt=$(Perl -e 'use POSIX;print strftime "%d/%m/%Y%",localtime time-86400;')

pax> echo $dt
17/08/2010
12
paxdiablo
dt=$(date --date yesterday "+%a %d/%m/%Y")
echo $dt
65
polemon

Linuxでは、次を使用できます。

date -d "-1 days" +"%a %d/%m/%Y"
48
z1x2

以下に示すようにGNU dateコマンドを使用できます

過去の日付を取得する

昨日と過去の日付を取得するには、文字列day agoを使用します。

日付--date = '昨日'

日付--date = '1日前'

日付--date = '10日前 '

日付--date = '10週間前 '

日付--date = '10か月前 '

日付--date = '10年前 '

未来の日付を取得する

明日と明後日(明日+ N)を取得するには、次のようにday Wordを使用して将来の日付を取得します。

日付--date = '明日'

日付--date = '1日'

日付--date = '10日 '

日付--date = '10週 '

date --date = '10 month '

日付--date = '10年 '

12
ramit girdhar

MacまたはBSD、または--dateオプションのない何かを使用している場合は、次を使用できます。

date -r `expr \`date +%s\` - 86400` '+%a %d/%m/%Y'

更新:またはおそらく...

date -r $((`date +%s` - 86400)) '+%a %d/%m/%Y'
9
DigitalRoss

Linuxにシェルスクリプトがあり、次のコードが機能しました。

#!/bin/bash
yesterday=`TZ=EST+24 date +%Y%m%d` # Yesterday is a variable
mkdir $yesterday # creates a directory with  YYYYMMDD format
6
jujuBee

少なくとも2つのオプションがあります

  1. Perlを使用します。

    Perl -e '@T=localtime(time-86400);printf("%02d/%02d/%02d",$T[4]+1,$T[3],$T[5]+1900)'
    
  2. インストールGNU date(それはsh_utils私が正しく覚えていればパッケージ

    date --date yesterday "+%a %d/%m/%Y" | read dt
    echo ${dt}
    
  3. これが機能するかどうかはわかりませんが、負のタイムゾーンを使用できる場合があります。現在のタイムゾーンの24時間前のタイムゾーンを使用する場合、dateを使用できます。

4
Wolph

次の方法を試してください。

dt=`case "$OSTYPE" in darwin*) date -v-1d "+%s"; ;; *) date -d "1 days ago" "+%s"; esac`
echo $dt

LinuxとOSXの両方で動作します。

3
kenorb

以下に、Solaris 1でテストした最初の引数の前の日付を計算するへのkshスクリプトを示します。

#!/bin/ksh
 sep=""
 today=$(date '+%Y%m%d')
 today=${1:-today}
 ty=`echo $today|cut -b1-4` # today year
 tm=`echo $today|cut -b5-6` # today month
 td=`echo $today|cut -b7-8` # today day
 yy=0 # yesterday year
 ym=0 # yesterday month
 yd=0 # yesterday day

 if [ td -gt 1 ];
 then
         # today is not first of month
         let yy=ty       # same year
         let ym=tm       # same month
         let yd=td-1     # previous day
 else
         # today is first of month
         if [ tm -gt 1 ];
         then
                 # today is not first of year
                 let yy=ty       # same year
                 let ym=tm-1     # previous month
                 if [ ym -eq 1 -o ym -eq 3 -o ym -eq 5 -o ym -eq 7 -o ym -eq 8 -o ym -     eq 10 -o ym -eq 12 ];
                 then
                         let yd=31
                 fi
                 if [ ym -eq 4 -o ym -eq 6 -o ym -eq 9 -o ym -eq 11 ];
                 then
                         let yd=30
                 fi
                 if [ ym -eq 2 ];
                 then
                         # shit... :)
                         if [ ty%4 -eq 0 ];
                         then
                                 if [ ty%100 -eq 0 ];
                                 then
                                         if [ ty%400 -eq 0 ];
                                         then
                                         #echo divisible by 4, by 100, by 400
                                                 leap=1 
                                         else
                                         #echo divisible by 4, by 100, not by 400
                                                 leap=0
                                         fi
                                 else
                                         #echo divisible by 4, not by 100
                                         leap=1 
                                 fi
                         else
                                 #echo not divisible by 4
                                 leap=0 # not divisible by four
                         fi
                         let yd=28+leap
                 fi
         else
                 # today is first of year
                 # yesterday was 31-12-yy
                 let yy=ty-1     # previous year
                 let ym=12
                 let yd=31
         fi
 fi
 printf "%4d${sep}%02d${sep}%02d\n" $yy $ym $yd

テスト

bin$ for date in 20110902 20110901 20110812 20110801 20110301 20100301 20080301 21000301 20000301 20000101 ; do yesterday $date; done
20110901
20110831
20110811
20110731
20110228
20100228
20080229
21000228
20000229
19991231

皆さんの助けに感謝しますが、私はHP-UXを使用しているため(結局、支払いが多ければ多いほど、機能も少なくなります)、Perlに頼らなければなりませんでした。

Perl -e '@T=localtime(time-86400);printf("%02d/%02d/%04d",$T[3],$T[4]+1,$T[5]+1900)' | read dt
2
Chris

HP-UXインストールにTclがインストールされている場合、日付計算が非常に読みやすくなることがあります(残念ながら、TclシェルにはPerlのようなNice "-e"オプションがありません)。

dt=$(echo 'puts [clock format [clock scan yesterday] -format "%a %d/%m/%Y"]' | tclsh)
echo "yesterday was $dt"

これは、すべての夏時間をわずらわせます。

2
glenn jackman
$var=$TZ;
TZ=$TZ+24;
date;
TZ=$var;

昨日AIXで取得し、TZ変数を元に戻します

2
santymano

ksh93:

dt=${ printf "%(%a %d/%m/%Y)T" yesterday; }

または:

dt=$(printf "%(%a %d/%m/%Y)T" yesterday)

1つ目は同じプロセスで実行され、2つ目はサブシェルで実行されます。

2
danlei

pythonへのアクセス権がある場合、これはyyyy-mm-dd任意のn日前の日付値:

function get_n_days_ago {
  local days=$1
  python -c "import datetime; print (datetime.date.today() - datetime.timedelta(${days})).isoformat()"
}

# today is 2014-08-24

$ get_n_days_ago 1
2014-08-23

$ get_n_days_ago 2
2014-08-22
2
wuster

--yesterdayをサポートする日付のバージョンがなく、Perlを使用したくない場合は、この便利なkshスクリプトを使用できます。デフォルトでは、昨日の日付を返しますが、数値を入力することができ、過去何日前の日付を示します。過去を見ていると、少し遅くなります。 10万日前は1738年1月30日でしたが、私のシステムではそれを理解するのに28秒かかりました。

    #! /bin/ksh -p

    t=`date +%j`
    ago=$1
    ago=${ago:=1} # in days
    y=`date +%Y`

    function build_year {
            set -A j X $( for m in 01 02 03 04 05 06 07 08 09 10 11 12
                    {
                            cal $m $y | sed -e '1,2d' -e 's/^/ /' -e "s/ \([0-9]\)/ $m\/\1/g"
                    } )
            yeardays=$(( ${#j[*]} - 1 ))
    }

    build_year

    until [ $ago -lt $t ]
    do
            (( y=y-1 ))
            build_year
            (( ago = ago - t ))
            t=$yeardays
    done

    print ${j[$(( t - ago ))]}/$y
2
Ken Beer

すべての良い答えですが、残念ながらそれらのどれも私のために働きませんでした。だから私は何か古い学校を書かなければなりませんでした。 (私は最小限のLinux OS上にいました)

$ date -d @$( echo $(( $(date +%s)-$((60*60*24)) )) )

これを日付の通常のフォーマットと組み合わせることができます。例えば。

$ date -d @$( echo $(( $(date +%s)-$((60*60*24)) )) ) +%Y-%m-%d

説明:epoc秒(-dオプション)で日付を入力します。これから、1日相当の秒を減算します。これにより、正確に1日前の日付が得られます。

2
Gautam

Hp-UXの場合、以下のコマンドのみが機能しました。

TZ = aaa24日付+%Y%m%d

次のように使用できます。

ydate = `TZ = aaa24 date +%Y%m%d`

エコー$ ydate

1
Anvesh