写一个shell脚本,定义两组日期分别为workday和holiday,当天日期在workday组里执行test1,当天日期在holiday组里执行test2。
时间: 2024-03-20 11:44:42 浏览: 14
好的,我可以为您提供一个参考脚本,如下所示:
```
#!/bin/bash
# 定义工作日和假期的日期,可以根据实际情况修改
workday=( "2022-01-03" "2022-01-04" "2022-01-05" "2022-01-06" "2022-01-07" )
holiday=( "2022-01-01" "2022-01-02" )
# 获取当前日期
today=$(date +%Y-%m-%d)
# 判断今天是否是工作日
if [[ "${workday[@]}" =~ "${today}" ]]; then
# 如果是工作日,执行test1
/path/to/test1
elif [[ "${holiday[@]}" =~ "${today}" ]]; then
# 如果是假期,执行test2
/path/to/test2
else
# 如果不是工作日也不是假期,输出错误信息
echo "Error: Unknown date ${today}"
fi
```
请注意,您需要将`/path/to/test1`和`/path/to/test2`替换为您实际的可执行文件路径。此外,您可能还需要根据实际情况修改日期数组和日期格式。
相关问题
帮我写一个shell脚本,把2023年所有日期分成工作日和节假日,并进行分类,第一类是当天是工作日到下一个日期是工作日的,第二类是当天是工作日到下一天是节假日的,第三类是当天是节假日到下一天是节假日的,第四类是当天是节假日到下一天是工作日的。
好的,以下是一个实现该功能的Shell脚本示例:
```shell
#!/bin/bash
# 获取2023年所有日期
DATES=$(seq -w 20230101 20231231)
# 定义工作日和节假日数组
WORKDAYS=()
HOLIDAYS=()
# 遍历每一个日期
for date in ${DATES[@]}; do
# 获取该日期的星期几
WEEKDAY=$(date -d $date +%u)
# 如果是星期六或星期日,则为节假日
if [ $WEEKDAY -eq 6 ] || [ $WEEKDAY -eq 7 ]; then
HOLIDAYS+=($date)
else
WORKDAYS+=($date)
fi
done
# 定义四个分类数组
WORKDAY_TO_WORKDAY=()
WORKDAY_TO_HOLIDAY=()
HOLIDAY_TO_HOLIDAY=()
HOLIDAY_TO_WORKDAY=()
# 遍历工作日数组
for i in $(seq 0 $((${#WORKDAYS[@]} - 2))); do
# 获取下一个日期
NEXT_DATE=$(date -d "${WORKDAYS[$i+1]} 1 day ago")
# 判断下一个日期是否为工作日
if [[ ! " ${WORKDAYS[@]} " =~ " ${NEXT_DATE} " ]]; then
WORKDAY_TO_HOLIDAY+=(${WORKDAYS[$i]})
else
WORKDAY_TO_WORKDAY+=(${WORKDAYS[$i]})
fi
done
# 遍历节假日数组
for i in $(seq 0 $((${#HOLIDAYS[@]} - 2))); do
# 获取下一个日期
NEXT_DATE=$(date -d "${HOLIDAYS[$i+1]} 1 day ago")
# 判断下一个日期是否为节假日
if [[ " ${HOLIDAYS[@]} " =~ " ${NEXT_DATE} " ]]; then
HOLIDAY_TO_HOLIDAY+=(${HOLIDAYS[$i]})
else
HOLIDAY_TO_WORKDAY+=(${HOLIDAYS[$i]})
fi
done
# 输出四个分类数组
echo "工作日到工作日:${WORKDAY_TO_WORKDAY[@]}"
echo "工作日到节假日:${WORKDAY_TO_HOLIDAY[@]}"
echo "节假日到节假日:${HOLIDAY_TO_HOLIDAY[@]}"
echo "节假日到工作日:${HOLIDAY_TO_WORKDAY[@]}"
```
该脚本先获取2023年所有日期,并判断每个日期是工作日还是节假日,分别加入对应的数组。然后遍历工作日和节假日数组,根据下一个日期是工作日还是节假日,将其分为四类。最后输出四个分类数组。
注意:该脚本依赖于系统的`date`命令,可能在不同操作系统或版本上有差异。
请扮演excel专家角色帮我写一个公示,i列等于c列日期➕24个工作日
好的,以下是你需要的公式。在I2单元格输入以下公式:
`=WORKDAY(C2,24)`
然后将该公式拖动到I列的所有单元格即可。
这个公式使用了Excel的WORKDAY函数来计算C列日期之后的24个工作日的日期。该函数的第一个参数是开始日期,第二个参数是要添加的工作日天数。最终,I列将显示C列日期之后的24个工作日的日期。
相关推荐
![zip](https://img-home.csdnimg.cn/images/20210720083736.png)
![zip](https://img-home.csdnimg.cn/images/20210720083736.png)
![zip](https://img-home.csdnimg.cn/images/20210720083736.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)