新手在这里打击脚本,如果你有时间可以使用一些帮助。我的客户上传,每个客户都有一个文件名的日期戳,如下所示:
* 20170815041135
* 20170820041135
* 20170823071727
* 20170826040609
* 20170828050704
* 20170830153011
我需要计算每次上传之间的天数,然后找到列出的上传的平均间隔
我可以使用此命令找到两个日期之间的日期差异
echo $(( ($(date --date="20170831" +'%s' ) - $(date --date="20170821" +'%s')) / (60*60*24) ))
要做多个日期我已经读过我需要一个数组,所以这是我在数组中的上传日期范围。
array=( `20170830153011`,`20170828050704`,`20170826040609`,`20170823071727`,`20170820041135`,`20170815041135` )
我读过我需要像这样循环计算
for i in "${array[@]}" do
?
如何将数组日期添加到计算中?
答案 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函数知道从那个日期开始考虑夏令时。