我要生成的文件列表,其中名称由${filename}.${date}
,例如file.20111101
, file.20120703
,从November 1, 2011
直到今天,它应该不包括周末。
谢谢。
我要生成的文件列表,其中名称由${filename}.${date}
,例如file.20111101
, file.20120703
,从November 1, 2011
直到今天,它应该不包括周末。
谢谢。
试试这个2011年
for y in 2011; do
for m in {1..12}; do
for d in `cal -m $m $y|tail -n +3|cut -c 1-15`; do
printf "file.%04d%02d%02d\n" $y $m $d;
done;
done;
done
这或为NOV-2011 DEC-2013
for ym in {2011' '{11,12},{2012..2013}' '{1..12}}; do
read y m <<<$ym;
for d in `cal -m $m $y|tail -n +3|cut -c 1-15`; do
printf "file.%04d%02d%02d\n" $y $m $d;
done;
done
或者直到本月底“硬”
for ym in {2011' '{11,12},2012' '{1..7}};do
read y m <<<$ym;
for d in `cal -m $m $y|tail -n +3|cut -c 1-15`;do
printf "file.%04d%02d%02d\n" $y $m $d;
done;
done
这可能会为你(GNU日期,SED和Bash)工作:
seq 0 $((($(date +%s)-$(date -d 20111101 +%s))/86400)) |
sed '5~7d;6~7d' |
xargs -l1 -I '{}' date -d '+{} days 20111101' +file.%Y%m%d
说明:
seq
提供天的序列从20111101
到today
sed
过滤掉周末 xargs
饲料日参数的date
命令。 与GAWK A液:
gawk -v START_DATE="2011 11 01 0 0 0" -v FILE="file" '
BEGIN {
END_DATE = strftime( "%Y %m %d 0 0 0", systime() )
while ( START_DATE <= END_DATE ) {
split( START_DATE, DATE )
if ( strftime( "%u", mktime( START_DATE ) ) < 6 ) print FILE "." DATE[ 1 ] DATE[ 2 ] DATE[ 3 ]
START_DATE = strftime( "%Y %m %d 0 0 0", mktime( DATE[ 1 ] " " DATE[ 2 ] " " ( DATE[ 3 ]+1 ) " 0 0 0" ) )
}
}
'
这将使用mktime的一个很好的属性,当你增加日期组成部分之一,可自动找到正确的日期(如“2012-02-33”变成了“2012-03-04”)。
另一种选择是使用dateseq
从dateutils
( http://www.fresse.org/dateutils/#dateseq )。
$ dateseq 2017-03-25 $(date +%F) --skip sat,sun -ffile.%Y%m%d
file.20170327
file.20170328
file.20170329
file.20170330
file.20170331
file.20170403
file.20170404
file.20170405
file.20170406
file.20170407