如何创建一个包含从day1到dayN的日期列的数据文件?

如何创建一个包含从day1到dayN的日期列的数据文件?

我想知道是否可以在从过去的某一年到最近或今天的某一天的列中生成每小时或每天的时间步日期。更清楚地说,我想创建从 2000-10-10 100 到 2012-12-31 2400 的一列数据。输出文件将如下所示

Date 

2000-01-01 100
2000-01-01 200
2000-01-01 300
.
.
.
.
.
2012-12-31 2400

答案1

#!/bin/bash

day=2000-01-01
end=2012-12-31

echo Date > output.file

until [[ $day > $end ]]; do
    printf "$day %d\n" $(seq 100 100 2400)
    day=$(date -d "$day + 1 day" +"%Y-%m-%d")
done >> output.file

答案2

ksh93

d1=$(printf '%(%s)T\n' "2000-01-01 01:00:00")
d2=$(printf '%(%s)T\n' "2013-01-01 00:00:00")
for ((d=d1;d<d2;d+=3600)); do
  printf '%(%F %-H%M)T\n' "#$d"
done

zsh

zmodload zsh/datetime
strftime -rs d1 '%Y%m%d%H%M' 201201010100
strftime -rs d2 '%Y%m%d%H%M' 201301010000
for ((d=d1;d<d2;d+=3600)) strftime '%F %-H%M' $d

perl

perl -MPOSIX -le '
  $d1=mktime 0,0,1,1,0,100;$d2=mktime 0,0,0,1,0,113;
  for ($d=$d1; $d<$d2; $d+=3600) {
    print strftime "%F %-H%M", localtime $d}'

使用 GNU awk

awk 'BEGIN {d1=mktime("2000 01 01 01 00 00")
            d2=mktime("2013 01 01 00 00 00")
            for (d=d1;d<d2;d+=3600)
              print strftime("%F %-H%M",d)}'

请注意,在 DST 更改时间的所有上述情况下,如果在以 DST 作为时钟的时区中,某些小时将被跳过或输出两次。

我们从 000 数到 2300,而不是 100 到 2400。

答案3

由于问题变得更容易理解,下面的小脚本可以做类似的事情。

#!/bin/bash

i=1
c=100

while ((c>i))
    do
    echo "$(date +%F)" $c >> thisfile
    sleep 5
    echo "$(date +%F)" $((c+=100))
    done

我希望这是不言自明的

我已经使用了sleep 5但是要准确地每小时生成这条线,您可以使用类似的东西sleep $((60*60))

相关内容