如何将我的数组日期添加到datediff计算中

时间:2017-09-01 18:26:48

标签: arrays bash average datediff

新手在这里打击脚本,如果你有时间可以使用一些帮助。我的客户上传,每个客户都有一个文件名的日期戳,如下所示:

* 20170815041135 
* 20170820041135 
* 20170823071727 
* 20170826040609   
* 20170828050704 
* 20170830153011

我需要计算每次上传之间的天数,然后找到列出的上传的平均间隔

我可以使用此命令找到两个日期之间的日期差异

echo $(( ($(date --date="20170831" +'%s' ) - $(date --date="20170821" +'%s')) / (60*60*24) )) 

给出10

要做多个日期我已经读过我需要一个数组,所以这是我在数组中的上传日期范围。

array=( `20170830153011`,`20170828050704`,`20170826040609`,`20170823071727`,`20170820041135`,`20170815041135` )

我读过我需要像这样循环计算

for i in "${array[@]}" do 
  ?

如何将数组日期添加到计算中?

2 个答案:

答案 0 :(得分:1)

您在数组中的日期时间:

timestamps=(
    20170815041135
    20170820041135
    20170823071727
    20170826040609
    20170828050704
    20170830153011
)

现在让我们将它们转换为纪元时代:

epochs=()
for timestamp in "${timestamps[@]}"; do 
    iso8601=$(sed -r 's/(....)(..)(..)(..)(..)(..)/\1-\2-\3T\4:\5:\6/' <<<"$timestamp")
    epochs+=( "$(date -d "$iso8601" "+%s")" )
done
printf "%s\n" "${epochs[@]}"
1502784695
1503216695
1503487047
1503734769
1503911224
1504121411

现在我们可以迭代它们来计算差异。请注意,bash数组索引从零开始:

n=0
sum=0
for ((i=1; i < "${#epochs[@]}"; i++ )); do 
    ((n++, diff=(${epochs[i]} - ${epochs[i-1]}), sum+=diff))
    echo "diff $n = $diff seconds = $((diff/86400)) days"
done
echo "average = $((sum/n)) seconds = $((sum/n/86400)) days"
diff 1 = 432000 seconds = 5 days
diff 2 = 270352 seconds = 3 days
diff 3 = 247722 seconds = 2 days
diff 4 = 176455 seconds = 2 days
diff 5 = 210187 seconds = 2 days
average = 267343 seconds = 3 days

答案 1 :(得分:0)

从1970年开始以秒为单位转换日期。 计算差异。 我希望bash date函数知道从那个日期开始考虑夏令时。