gpt4 book ai didi

linux - 一个月中每一天的两次之间的日期值

转载 作者:太空宇宙 更新时间:2023-11-04 09:10:25 25 4
gpt4 key购买 nike

我有一项任务需要从 API 中提取数据。我需要指定仅在给定月份的每一天的早上 7 点到晚上 9 点之间收集数据。

这将是一个 Bash 脚本,将在每月 1 号的 00:01 使用 cron 运行。

API 将只接受大纪元时间。脚本需要足够灵活,这样我就不必在一年中的每一天都编写代码。

我无法解决这个问题。我可以通过上午 7 点的纪元时间和晚上 9 点的纪元时间获取一个月的第一天,API 将接受这两个纪元值并在这两个时间之间进行查找。

我还可以在上午 7 点和晚上 9 点再次获取本月的最后一天的纪元时间。

我无法弄清楚的是上午 7 点纪元和晚上 9 点纪元的每月第一天和最后一天之间的日子。

START_LAST_MONTH=$(date "+%Y-%m-01" -d "-1 Month");
START_DAY_SEVEN_AM_EPOCH_DATE=$(date +%s -d"$START_LAST_MONTH 7am");
START_DAY_NINE_PM_EPOCH_DATE=$(date +%s -d"$START_LAST_MONTH 9pm");


END_LAST_MONTH=$(date "+%Y-%m-%d" -d "$START_LAST_MONTH +1 month -1 day");
END_DAY_SEVEN_AM_EPOCH_DATE=$(date +%s -d"$END_LAST_MONTH 7am");
END_DAY_NINE_PM_EPOCH_DATE=$(date +%s -d"$END_LAST_MONTH 9pm");

我正在考虑实现此目的的一种方法是将 86400 秒添加到早上 7 点和晚上 9 点的 START_DAY 变量,通过这样做创建新变量,然后向上增加一天,直到 END_DAY 早上 7 点和晚上 9 点 Epoch 时间变量被命中。这对于每个月来说应该是灵活的,因为一个月中的天数不同。

但这超出了我的 bash 脚本编写技能,我希望学习如何实现这一点,因此我们将不胜感激,从另一个角度来看这个问题也很好。

更新:

我现在在 bash 脚本中有这个

#!/bin/sh -x

START_LAST_MONTH=$(date "+%Y-%m-01" -d "-1 Month");
START_DAY_SEVEN_AM_EPOCH_DATE=$(date +%s -d"$START_LAST_MONTH 7am");
START_DAY_NINE_PM_EPOCH_DATE=$(date +%s -d"$START_LAST_MONTH 9pm");


END_LAST_MONTH=$(date "+%Y-%m-%d" -d "$START_LAST_MONTH +1 month -1 day");
END_DAY_SEVEN_AM_EPOCH_DATE=$(date +%s -d"$END_LAST_MONTH 7am");
END_DAY_NINE_PM_EPOCH_DATE=$(date +%s -d"$END_LAST_MONTH 9pm");

until [ $END_DAY_SEVEN_AM_EPOCH_DATE ]
do
let ADD_ONE_DAY=$START_DAY_SEVEN_AM_EPOCH_DATE+86400
echo $ADD_ONE_DAY
done


但它根本不响应 ADD_ONE_DAY 变量。当使用 -X 进行调试时,它会到达这里:直到 [ $END_DAY_SEVEN_AM_EPOCH_DATE ] 并且不会做任何进一步的事情。

最佳答案

您更新的示例代码的问题是,在循环条件中,您实际上只检查 $END_DAY_SEVEN_AM_EPOCH_DATE 不为空 - 这只是在上面设置了两行,因此永远不会执行循环体.

要使您的示例按预期工作,请尝试进行以下修改:

#!/bin/sh -x

START_LAST_MONTH=$(date "+%Y-%m-01" -d "-1 Month");
START_DAY_SEVEN_AM_EPOCH_DATE=$(date +%s -d"$START_LAST_MONTH 7am");
START_DAY_NINE_PM_EPOCH_DATE=$(date +%s -d"$START_LAST_MONTH 9pm");


END_LAST_MONTH=$(date "+%Y-%m-%d" -d "$START_LAST_MONTH +1 month -1 day");
END_DAY_SEVEN_AM_EPOCH_DATE=$(date +%s -d"$END_LAST_MONTH 7am");
END_DAY_NINE_PM_EPOCH_DATE=$(date +%s -d"$END_LAST_MONTH 9pm");

ADD_ONE_DAY=$START_DAY_SEVEN_AM_EPOCH_DATE
until [ "$ADD_ONE_DAY" -gt "$END_DAY_SEVEN_AM_EPOCH_DATE" ]
do
let ADD_ONE_DAY=$ADD_ONE_DAY+86400
echo $ADD_ONE_DAY
done
  1. 调整循环条件以测试 $ADD_ONE_DAY 是否大于 $END_DAY_SEVEN_AM_EPOCH_DATE
  2. 在循环之前用$START_DAY_SEVEN_AM_EPOCH_DATE初始化$ADD_ONE_DAY
  3. 在循环中将 $ADD_ONE_DAY 增加一天(而不是 $START_DAY_SEVEN_AM_EPOCH_DATE,这会导致始终相同的值,即无限循环)

为了使用 seq 命令遍历一个月中的所有日子,另一个解决方案可能是:

#!/bin/bash

START_LAST_MONTH=$(date "+%Y-%m-01" -d "-1 Month")
END_LAST_MONTH=$(date "+%Y-%m-%d" -d "$START_LAST_MONTH +1 month -1 day")

CURRENT_YEAR=$(date +%Y -d "-1 Month")
CURRENT_MONTH=$(date +%m -d "-1 Month")
LAST_DAY_OF_MONTH=$(date +%d -d "$END_LAST_MONTH");

for CURRENT_DAY in $(seq -w 1 "$LAST_DAY_OF_MONTH"); do
CURRENT_DATE="$CURRENT_YEAR-$CURRENT_MONTH-$CURRENT_DAY"
CURRENT_DAY_SEVEN_AM_EPOCH=$(date +%s -d"$CURRENT_DATE 7am")
CURRENT_DAY_NINE_PM_EPOCH=$(date +%s -d"$CURRENT_DATE 9pm")

echo "$CURRENT_DAY_SEVEN_AM_EPOCH - $CURRENT_DAY_NINE_PM_EPOCH"
done

此处 seq -w 1 "$LAST_DAY_OF_MONTH" 将生成从 1 到相应月份最后一天的序列,-w 输出带有 等宽必要时补0,即“01”、“02”、……

关于linux - 一个月中每一天的两次之间的日期值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57513287/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com