1か月前のすべてのサブディレクトリを削除する必要があります。ただし、その月の最後の3ヶ月のデータは無視する必要があります。
状況data representation
は次のとおりです。
bkp_01102014 bkp_04102014 bkp_07102014 bkp_11102014 bkp_15112014
...................
...................
bkp_24112014 bkp_27112014 bkp_30062014 bkp_31072 bkp_20092014
または、他のコマンドを使用してfind
それらを自動化するにはどうすればよいですか?
答え1
このファイルの名前を変更する必要はないと思います。ファイル名をすぐに変換し(最初のsed)、日付と比較して(awk)、一致するファイル名を再変換することができます(2番目のsed)。
find parent/directory -maxdepth 1 -type d -name 'bkp_*' | \
sed 's#parent/directory/bkp_\(..\)\(..\)\(....\)#\3\2\1#' | \
awk -v date=$(date --date='3 months ago' +%Y%m%d) '$0<$date{print $0}' | \
sed 's#\(....\)\(..\)\(..\)#parent/directory/bkp_\3\2\1#' | \
xargs rm -r
まず、xargs rm部分なしでテストする必要があります!
答え2
Bashスクリプトを書いてみてください。役立つことを確認してください。
#!/bin/bash
NOW=`date +%s`
last_day()
{
case $MM in
01|03|05|07|08|10|12 )
echo "31" ;;
04|06|09|11 )
echo "30" ;;
02 )
echo "28" ;;
esac
}
for file in `ls -1 bkp*`
do
# echo $file
DATE=`echo $file | tr -cd [0-9]` # Extract Day of the Month from file name
YY=`echo $DATE | cut -c5-8` # Extract Year from file name
MM=`echo $DATE | cut -c3-4` # Extract Month of Year fro file name
DD=`echo $DATE | cut -c1-2`
FDATE=`echo ${YY}${MM}${DD}` # Re-arrange the date
FDATE=`date +%s -d $FDATE` # Date in terms of seconds
# echo "FILEDATE= $FDATE"
DIFF=`echo "$NOW - $FDATE" | bc` # Difference between NOW and FILEDATE in Seconds
# echo "DIFF FROM NOW= $DIFF"
DIFFDAYS=`echo "$DIFF / 86400" | bc` # Difference in terms of DAYS
DIFFMONTHS=`echo "$DIFFDAYS / 30" | bc` # Difference in terms of MONTHS
# echo "DIFF IN DAYS= $DIFFDAYS"
# echo "DIFF IN MONTHS = $DIFFMONTHS"
LASTDAY=$(last_day $MM) # To determine whether it is a last day of month
# echo $LASTDAY
if [ $DIFFMONTHS -ge 1 ]
then
if [ $DD -eq $LASTDAY -a $DIFFMONTHS -ge 4 ]
then
rm -rf $file
else
rm -rf $file
fi
fi
done
テスト出力:
スクリプトを実行する前に:
$ ls
bkp_20082013 bkp_20082014 bkp_20112014
bkp_20071989 bkp_20092014 bkp_30112014
bkp_20072014 bkp_20102014 bkp_31102014
スクリプトを実行した後:
bkp_20112014 bkp_30112014