get_date.sh
#!/usr/bin
####################################################################
#日期函数处理
#获取某个月份的天数 getMonthMaxDay yyyy-mm-dd 返回格式:yyyy-mm-dd
#获取后一天日期 getNextDate yyyy-mm-dd 返回格式:yyyy-mm-dd
#获取后面N天的日期 getNextNDate yyyy-mm-dd N 返回格式:yyyy-mm-dd
#获取前一天日期 getLastDate yyyy-mm-dd 返回格式:yyyy-mm-dd
#获取当前数据日期前N天的日期 getLastNDate yyyy-mm-dd N 返回格式:yyyy-mm-dd
#获取当日对应的月的月末日期 getEndMonDay yyyy-mm-dd 返回格式:yyyy-mm-dd
#获取下月的月末日期 getNextMonEndDay yyyy-mm-dd 返回格式:yyyy-mm-dd
#获取下月同期日期 getNextMonthDay yyyy-mm-dd 返回格式:yyyy-mm-dd
#获取上月同期日期 getLastMonthDay yyyy-mm-dd 返回格式:yyyy-mm-dd
#获取上月同期数据日期 getLMDataDay yyyy-mm-dd 返回格式:yyyy-mm-dd 注:若本月日期是月末则上月同期始终为月末日期,不是月末则本月的日期位比
上月月末日期大于等于则取上月倒数第二天
#获取去年同期日期 getLastYearDay yyyy-mm-dd 返回格式:yyyy-mm-dd
####################################################################
###获取某个月份的天数
getMonthMaxDay(){
virdate=`echo ${1}`;
virM=`echo ${1}`;
viryear=`echo ${virdate}|awk -F "-" '{print $1}'` ;
virmonth=`echo ${virdate}|awk -F "-" '{print $2}'` ;
virday=`echo ${virdate}|awk -F "-" '{print $3}'` ;
#参数为空
if [ ! -n "$virmonth" ];
then
virmonth=`echo ${virM}`;
fi
if [ ! -n "$virmonth" ];
then
return 0
fi
if [ $virmonth -gt 0 -a $virmonth -lt 13 ]
then
case $virmonth in 1|01|3|03|5|05|7|07|8|08|10|12 )
maxday=31 ;;
4|04|6|06|9|09|11 )
maxday=30 ;;
2|02 )
if [ `expr $viryear % 4` -eq 0 ]
then
if [ `expr $viryear % 400` -eq 0 ]
then
maxday=29
elif [ `expr $viryear % 100` -eq 0 ]
then
maxday=28
else
maxday=29
fi
else
maxday=28
fi ;;
esac
fi
echo $maxday
}
####获取后一天日期
getNextDate() {
virdate=`echo ${1}`;
#划分年月日
viryear=`echo ${virdate}|awk -F "-" '{print $1}'` ;
virmonth=`echo ${virdate}|awk -F "-" '{print $2}'` ;
virday=`echo ${virdate}|awk -F "-" '{print $3}'` ;
#获取某月最后一天
virmonth_endday=`echo $(getMonthMaxDay $virdate )` ;
virday=` expr $virday + 1 `;
##当日+1后日期大于月末则月份+1,同时当日设置为1号;月份+1大于12后则年份+1,同时月份设置为1月
if [ ${virday} -gt ${virmonth_endday} ]
then
virday=` expr 0 + 1 `;
virmonth=` expr $virmonth + 1 `;
if [ $virmonth -gt 12 ]
then
virmonth=` expr 0 + 1 `;
viryear=` expr ${viryear} + 1 `;
fi
else
virmonth=` expr $virmonth + 0 `;
fi
##月份或者日期小于10将月份或者日期的字符前面加一个0,补足两位格式
if [ $virmonth -lt 10 ]
then
virmonth=`echo 0${virmonth}`;
fi
if [ $virday -lt 10 ]
then
virday=`echo 0${virday}`;
fi
virdate=`echo ${viryear}-${virmonth}-${virday}` ;
echo $virdate
}
##获取后面N天的日期
getNextNDate() {
virdate=`echo ${1}`;
LastN=`echo ${2}`;
#划分年月日
num=`echo 1`;
while [ ${num} -le ${LastN} ]
do
virdate=`echo $(getNextDate $virdate )` ;
num=` expr $num + 1 `;
done
echo ${virdate}
}
####获取前一天日期
getLastDate() {
virdate=`echo ${1}`;
#划分年月日
viryear=`echo ${virdate}|awk -F "-" '{print $1}'` ;
virmonth=`echo ${virdate}|awk -F "-" '{print $2}'` ;
virday=`echo ${virdate}|awk -F "-" '{print $3}'` ;
#获取某月最后一天
virmonth_endday=`echo $(getMonthMaxDay $virdate )` ;
virday=` expr $virday - 1 `;
##当日-1后日期小于等于0,同时当日设置上月月末,同时月份-1
if [ ${virday} -le 0 ]
then
virmonth=` expr $virmonth - 1 `;
if [ $virmonth -le 0 ]
then
viryear=` expr ${viryear} - 1 `;
virmonth=`echo 12`;
fi
##月份或者日期小于10将月份或者日期的字符前面加一个0,补足两位格式
if [ $virmonth -lt 10 ]
then
virmonth=`echo 0${virmonth}`;
fi
virday=`echo $(getMonthMaxDay ${viryear}-${virmonth}-01 )` ;
fi
if [ $virday -lt 10 ]
then
virday=`echo 0${virday}`;
fi
virdate=`echo ${viryear}-${virmonth}-${virday}` ;
echo $virdate
}
#获取当前数据日期前N天的日期
getLastNDate() {
virdate=`echo ${1}`;
LastN=`echo ${2}`;
#划分年月日
num=`echo 1`;
while [ ${num} -le ${LastN} ]
do
virdate=`echo $(getLastDate $virdate )` ;
num=` expr $num + 1 `;
done
echo ${virdate}
}
###获取当日对应的月的月末日期
getEndMonDay() {
virdate=`echo ${1}`;
viryear=`echo ${virdate}|awk -F "-" '{print $1}'` ;
virmonth=`echo ${virdate}|awk -F "-" '{print $2}'` ;
virday=`echo ${virdate}|awk -F "-" '{print $3}'` ;
maxday=`echo $(getMonthMaxDay $virdate )` ;
virdate=`echo ${viryear}-${virmonth}-${maxday}` ;
echo $virdate
}
###获取下月的月末日期
getNextMonEndDay() {
virdate=`echo ${1}`;
virdate=`echo $(getNextMonthDay $virdate )` ;
virdate=`echo $(getEndMonDay $virdate )` ;
echo $virdate
}
####获取下月同期日期
getNextMonthDay() {
virdate=`echo ${1}`;
viryear=`echo ${virdate}|awk -F "-" '{print $1}'` ;
virmonth=`echo ${virdate}|awk -F "-" '{print $2}'` ;
virday=`echo ${virdate}|awk -F "-" '{print $3}'` ;
vir_cur_Endday=`echo $(getMonthMaxDay ${virdate} )` ;
vir_cur_day=` expr $virday + 0 `;
##月份+1
virmonth=` expr $virmonth + 1 `;
#----如果月份相加大于等于13则将月份置成1月
if [ $virmonth -gt 12 ]
then
virmonth=1;
viryear=` expr ${viryear} + 1 `;
fi
##月份小于10 需要前置补足一个0用两位表示月份
if [ $virmonth -lt 10 ]
then
virmonth=`echo 0${virmonth}`;
else
virmonth=`echo ${virmonth}`;
fi
vir_NextM_Endday=`echo $(getMonthMaxDay ${viryear}-${virmonth}-01 )` ;
virday=` expr $virday + 0 `;
###如果月份+1的后,月末日期小于传入的参数的日期则将同期设置成月末日期
if [ ${virday} -ge ${vir_NextM_Endday} ]
then
virday=`echo ${vir_NextM_Endday}`;
fi
###如果传入数据日期为当月月末日期,则下月同期就为月末日期
if [ ${vir_cur_day} -eq ${vir_cur_Endday} ]
then
virday=`echo ${vir_NextM_Endday}`;
fi
if [ $virday -lt 10 ]
then
virday=`echo 0${virday}`;
fi
virdate=`echo ${viryear}-${virmonth}-${virday}` ;
echo $virdate
}
####获取上月同期日期
getLastMonthDay() {
virdate=`echo ${1}`;
viryear=`echo ${virdate}|awk -F "-" '{print $1}'` ;
virmonth=`echo ${virdate}|awk -F "-" '{print $2}'` ;
virday=`echo ${virdate}|awk -F "-" '{print $3}'` ;
vir_cur_Endday=`echo $(getMonthMaxDay ${virdate} )` ;
vir_cur_day=` expr $virday + 0 `;
##月份+1
virmonth=` expr $virmonth - 1 `;
#----如果月份相加小于等于0则将月份置成12月
if [ $virmonth -le 0 ]
then
virmonth=12;
viryear=` expr ${viryear} - 1 `;
fi
##月份小于10 需要前置补足一个0用两位表示月份
if [ $virmonth -lt 10 ]
then
virmonth=`echo 0${virmonth}`;
else
virmonth=`echo ${virmonth}`;
fi
vir_LastM_Endday=`echo $(getMonthMaxDay ${viryear}-${virmonth}-01 )` ;
virday=` expr $virday + 0 `;
###如果月份-1的后,月末日期小于传入的参数的日期则将同期设置成月末日期
if [ ${virday} -ge ${vir_LastM_Endday} ]
then
virday=`echo ${vir_LastM_Endday}`;
fi
###如果传入数据日期为当月月末日期,则下月同期就为月末日期
if [ ${vir_cur_day} -eq ${vir_cur_Endday} ]
then
virday=`echo ${vir_LastM_Endday}`;
fi
if [ $virday -lt 10 ]
then
virday=`echo 0${virday}`;
fi
virdate=`echo ${viryear}-${virmonth}-${virday}` ;
echo $virdate
}
####获取上月同期数据日期--与前台展现算法一致(若本月日期是月末则上月同期始终为月末日期,不是月末则本月的日期位比上月月末日期大于等于则取上月倒数第二天)
getLMDataDay() {
virdate=`echo ${1}`;
virdate_End=`echo $(getEndMonDay $virdate )` ;
LMdate=`echo $(getLastMonthDay $virdate )` ;
LMdate_End=`echo $(getEndMonDay $LMdate )` ;
virdate_D=`echo $virdate|cut -c 9-10`
virdate_End_D=`echo $virdate_End|cut -c 9-10`
LMdate_D=`echo $LMdate|cut -c 9-10`
LMdate_End_D=`echo $LMdate_End|cut -c 9-10`
if [ ! ${virdate_D} -eq ${virdate_End_D} ]
then
if [ ${virdate_D} -ge ${LMdate_End_D} ]
then
LMdate=`echo $(getLastDate $LMdate )` ;
fi
fi
echo $LMdate
}
####获取去年同期日期(当月为月底则去年同期永远为月底日期)
getLastYearDay() {
virdate=`echo ${1}`;
viryear=`echo ${virdate}|awk -F "-" '{print $1}'` ;
virmonth=`echo ${virdate}|awk -F "-" '{print $2}'` ;
virday=`echo ${virdate}|awk -F "-" '{print $3}'` ;
vir_cur_Endday=`echo $(getMonthMaxDay ${virdate} )` ;
vir_cur_day=` expr $virday + 0 `;
viryear=` expr ${viryear} - 1 `;
vir_LastY_Endday=`echo $(getMonthMaxDay ${viryear}-${virmonth}-01 )` ;
virday=` expr $virday + 0 `;
###如果月份-1的后,月末日期小于传入的参数的日期则将同期设置成月末日期
if [ ${vir_cur_day} -eq ${vir_cur_Endday} ]
then
virday=`echo ${vir_LastY_Endday}`;
fi
if [ $virday -lt 10 ]
then
virday=`echo 0${virday}`;
fi
virdate=`echo ${viryear}-${virmonth}-${virday}` ;
echo $virdate
}
get_date.sh的更多相关文章
- 数据库备份并分离日志表(按月)sh 脚本
#!/bin/sh year=`date +%Y` month=`date +%m` day=`date +%d` hour=`date +%H` dir="/data/dbbackup/f ...
- Linux下如何查找.sh后缀的文件
find / -name *.sh或locate *.shfind 与locate的区别:locate 配合数据库查看文件位置 find 实际搜寻硬盘查询文件名称
- sh 测试网段在线主机
yum install nmap nmap -sP 192.168.21.1/24 查看网段在线主机 grep -vwf file1 file2 文件内容比较 #!/bin/bash # day=` ...
- Maven打包生成可运行bat/sh脚本文件
利用Maven的appassembler-maven-plugin插件,就可以实现自动打包可运行的脚本,还可以跨平台. <plugin> <groupId>org ...
- 记一个简单的保护if 的sh脚本
真是坑爹,就下面的sh,竟然也写了很久! if [ `pwd` != '/usr/xx/bin/tomcat' ] then echo "rstall is not allowed in c ...
- 主机巡检脚本:OSWatcher.sh
主机巡检脚本:OSWatcher.sh 2016-09-26更新,目前该脚本只支持Linux操作系统,后续有需求可以继续完善. 注意: 经测试,普通用户执行脚本可以顺利执行前9项检查: 第10项,普通 ...
- Oracle巡检脚本:ORAWatcher.sh
Oracle巡检脚本:ORAWatcher.sh #!/usr/bin/ksh echo "" echo "ORAWatcher Version:1.0.1" ...
- 解决:/bin/sh: 1: /home/**/custom_app.sh: Permission denied错误
出现如下错误,一般是执行权限不够. /bin/sh: : /home/custom_app.sh: Permission denied 解决方法是:cd 到此文件目录,对提示的文件赋予可执行权限或读写 ...
- SH Script Grammar
http://linux.about.com/library/cmd/blcmdl1_sh.htm http://pubs.opengroup.org/onlinepubs/9699919799/ut ...
随机推荐
- usleep和sleep
usleep 和 sleep 都是用于将进程挂起, 所不同的是前者在微秒级别, 后者在秒级别.
- apache2.4 只允许合法域名访问网站 禁止使用ip、非法域名访问
1.ip访问禁用ip访问 只能对应端口有效<VirtualHost *:80> ServerName xx.xx.xx.xx ServerAlias * <Location /> ...
- win32 socket编程(二)——TCP/IP
一.大端.小端法定义 1.1小端法(Little-Endian)就是低位字节排放在内存的低地址端即该值的起始地址,高位字节排放在内存的高地址端. (主机字节顺序) 1.2 大端法(Big-Endian ...
- netcore项目使用swagger开发
首先我创建一个netcore项目,我使用的工具是vs2019 这里需要注意的是,看情况选择是否开启身份验证,一般是没有需求的,这里因为我是测试使用所以需要取消勾兑为https配置,并且我没有启用doc ...
- pg_ctl - 启动,停止和重启 PostgreSQL 服务器
SYNOPSIS pg_ctl start [ -w ] [ -s ] [ -D datadir] [ -l filename] [ -o options] [ -p path] pg_ctl sto ...
- Linux性能优化从入门到实战:05 CPU篇:硬中断、软中断
软中断(softirq)会导致CPU 使用率升高 中断是系统用来响应硬件设备请求的一种机制,它会打断进程的正常调度和执行,然后调用内核中的中断处理程序来响应设备的请求.中断其实是一种异步的事件 ...
- mysql查询每个部门/班级前几名
Employee 表包含所有员工信息,每个员工有其对应的 Id, salary 和 department Id . +----+-------+--------+--------------+ | I ...
- HTTP post get request 时遇到特殊字符 ! @ # $ % ^ & * ( )
HTTP post get request 时遇到特殊字符 ! @ # $ % ^ & * ( ) 使用对应的编码替代 例如: curl ftp://username:pass@word@ex ...
- Flutter-ListTile
ListTile 通常用于在 Flutter 中填充 ListView.在这篇文章中,我将用可视化的例子来说明所有的参数. title title 参数可以接受任何小部件,但通常是文本小部件 List ...
- bzoj4128 Matrix 矩阵 BSGS
题目传送门 https://lydsy.com/JudgeOnline/problem.php?id=4128 题解 想了十分钟没有任何思路. 然后一眼瞥见一句话"数据保证在 \(p\) 内 ...