问题描述
数据滞后 - 10 天
跑步日 - 周二。
要求基于日期滞后:我必须将日历移回 10 天。然后我想找到星期二(可以在参数中指定任何工作日)。
我想从中获得每周报告。
指定此配置时,例如今天 11 至 2021 年 5 月
5 月 11 日 - 10 天 = 2021 年 5 月 1 日。在此之后,根据运行日(例如星期一),我的日历应移至 4 月 26 日。
最终结果是
(星期一)4 月 26 日至(星期日)5 月 2 日。
val format_w = new SimpleDateFormat("yyyy-MM-dd")
val cal_ins = Calendar.getInstance
cal_ins.add(Calendar.DATE,-datalaginterval)
val datlag_date = cal_ins.getTime()
logger.info("datalag date"+datlag_date)
cal_ins.add(Calendar.DATE,-7)
val startdate = cal_ins.getTime
val start_date = format_w.format(startdate)
println("start date-"+start_date)
// calculate sunday last week (moves cal 6 days fwd)
cal_ins.add(Calendar.DATE,6)
val enddate = cal_ins.getTime
val end_date = format_w.format(enddate)
println("End date-"+end_date)
我正在使用 Java Calendar
类。
解决方法
你的问题比较混乱。也许这会帮助您朝着正确的方向开始。
import java.time.LocalDate
import java.time.DayOfWeek
val lagDate: LocalDate = LocalDate.now() //today
.minusDays(9L) //less lag days
val nearestTues: LocalDate = //Tuesday closest to lag date
lagDate.minusDays(lagDate.getDayOfWeek().getValue() -
DayOfWeek.valueOf("TUESDAY").getValue())
val (tuesBefore,tuesAfter) = if (nearestTues isAfter lagDate)
(nearestTues.minusDays(7L),nearestTues)
else
(nearestTues,nearestTues.plusDays(7L))
,
java.time
与其他人一样,我强烈建议您使用 java.time,现代 Java 日期和时间 API,用于您的日期工作。我相信代码可以比其他答案更简单。原谅我的Java。我相信你会翻译成 Scala。
int lagDays = 10;
DayOfWeek runDay = DayOfWeek.TUESDAY;
LocalDate today = LocalDate.now(ZoneId.of("Africa/Ceuta"));
LocalDate start = today.minusDays(lagDays)
.with(TemporalAdjusters.previousOrSame(runDay));
LocalDate end = start.plusDays(6);
System.out.format("From %s through %s%n",start,end);
我刚才运行代码的时候,输出是:
从 2021-04-27 到 2021-05-03
如果要使用JVM的默认时区,使用:
LocalDate today = LocalDate.now(ZoneId.systemDefault());
.with(TemporalAdjusters.previousOrSame(runDay))
的工作原理:如果 10 天前已经是星期二,那就是您得到的日期。否则,您将获得上一个星期二,即 10 天前计算日期之前最近的星期二。在这个例子中,10 天前是 5 月 2 日星期日,所以我们得到了 4 月 27 日星期二。
链接
Oracle tutorial: Date Time 解释如何使用 java.time。