linux shell脚本操作日期记录

最近碰到个需求,按日导出每日的数据,然后导入另一个数据库。需要写个日期相关的脚本。这里总结下

bash 复制代码
#!/bin/bash

function dateFunc(){
	echo "从${2}到${3}"																																												
	next=`date -d "$2" +%s`
	start=${2}
	end=`date -d "$3" +%s`

	i=0
	while [ $next -lt $end ]
	do
		next=`date -d "${start} +${i} day" +%s`
		echo `date -d "${start} +${i} day" +%Y-%m-%d`
		((i=i+1))
		
	done
}

read -p " 请输入(yes/y/no/n):" input

case "$input" in
    [Yy][Ee][Ss]|[Yy])
        dateFunc $1 $2 $3
        ;;
    [Nn][Oo]|[Nn])
        echo "退出"
		exit
        ;;
    *)
        exit
        ;;
esac

echo "从当前日期往前`expr $1 + 1`推天"
for ((i=0;i<=${1};i++))
do
    echo "第${i}天"
	str=$(date -d "${i} day ago" +%Y-%m-%d)
	echo $str

done

echo "从当前日期到${2}"
t1=`date -d "$2" +%s`
t2=`date -d "$(date +%Y-%m-%d) 0:00:00" +%s`

i=0
while [ $t1 -lt $t2 ]
do
	echo $(date -d "${i} day ago" +%Y-%m-%d)
	t2=$(date -d "${i} day ago 0:00:00" +%s)
	((i=i+1))
	
done

运行情况如下:

bash 复制代码
# sh testDate.sh 5 2023-07-11 2023-07-20
 请输入(yes/y/no/n):y
从2023-07-11到2023-07-20
2023-07-11
2023-07-12
2023-07-13
2023-07-14
2023-07-15
2023-07-16
2023-07-17
2023-07-18
2023-07-19
2023-07-20
从当前日期往前6推天
第0天
2023-07-18
第1天
2023-07-17
第2天
2023-07-16
第3天
2023-07-15
第4天
2023-07-14
第5天
2023-07-13
从当前日期到2023-07-11
2023-07-18
2023-07-17
2023-07-16
2023-07-15
2023-07-14
2023-07-13
2023-07-12
2023-07-11

分别设想了三种情况

1、从某日到某日

2、从当前日期往前推N天

3、从某个日期到当前日期

plus:chatgpt是个写脚本是个好帮手

相关推荐
测试界的海飞丝40 分钟前
10道软件测试面试题及其答案:
服务器·测试工具·职场和发展
t198751281 小时前
在Ubuntu 22.04系统上安装libimobiledevice
linux·运维·ubuntu
skywalk81631 小时前
linux安装Code Server 以便Comate IDE和CodeBuddy等都可以远程连上来
linux·运维·服务器·vscode·comate
@游子2 小时前
内网渗透笔记-Day5
运维·服务器
晚风吹人醒.2 小时前
缓存中间件Redis安装及功能演示、企业案例
linux·数据库·redis·ubuntu·缓存·中间件
记得记得就1512 小时前
【Nginx 性能优化与防盗链】
运维·nginx·性能优化
Yawesh_best2 小时前
告别系统壁垒!WSL+cpolar 让跨平台开发效率翻倍
运维·服务器·数据库·笔记·web安全
V***u4532 小时前
MS SQL Server partition by 函数实战二 编排考场人员
java·服务器·开发语言
roman_日积跬步-终至千里2 小时前
【Docker】Docker Stop 后到底发生了什么?——从信号机制到优雅停机
运维·docker·容器
喵手2 小时前
云端智变:基于 DevUI 与 MateChat 打造下一代云原生智能运维中台实战教学!
运维·云原生·devui·matechat