如何使用bash中提供的工具生成一系列非周末日期?

时间:2012-07-03 15:19:45

标签: bash shell sed awk unix-timestamp

我想生成一个名称由${filename}.${date}组成的文件列表,例如file.20111101file.20120703,从今天开始November 1, 2011,它应该排除周末。

感谢。

4 个答案:

答案 0 :(得分:5)

试试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

答案 1 :(得分:2)

这可能适合你(GNU date,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提供从20111101today
  • 的一系列天数
  • sed过滤了周末
  • xargsdate命令提供日期参数。

答案 2 :(得分:0)

gawk的解决方案:

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”)。

答案 3 :(得分:0)

另一种选择是使用dateseqhttp://www.fresse.org/dateutils/#dateseq)中的dateutils

$ 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