使用Java只获得工作日

时间:2013-10-10 04:13:58

标签: java

我有一个要求,比如当我在我的数据库中的表中插入值时,我需要设置目标日期,它与插入日期相隔3个月。例如:如果我在2013年11月9日插入数据,我的目标日期将是2014年2月9日,2015年5月9日,依此类推。我也将这些目标日期存储在各自的列中。为此,我使用日历功能并将3个月添加到当前实例。现在,企业不希望我的目标日期在星期六或星期日到来。如果它来了,我需要添加所需的天数,以便它在工作日出现。

关于我们如何做到这一点的任何建议

2 个答案:

答案 0 :(得分:2)

从你已经知道的开始。您知道可以使用Calendar向/从中添加/减去值并生成结果值....

Calendar cal = Calendar.getInstance();
cal.clear();
cal.set(Calendar.DATE, 9);
cal.set(Calendar.MONTH, Calendar.NOVEMBER);
cal.set(Calendar.YEAR, 2013);
System.out.println("Start at " + cal.getTime());

cal.add(Calendar.MONTH, 3);
System.out.println("End at " + cal.getTime());

哪些输出......

Start at Sat Nov 09 00:00:00 EST 2013
End at Sun Feb 09 00:00:00 EST 2014

现在,你需要使用这个概念来推动这一天,直到它不是一个星期结束。您可以使用Calendar.DAY_OF_WEEK获取“日期”名称,只需根据您的业务规则向Calendar.DATE添加或减去一天,例如......

while (cal.get(Calendar.DAY_OF_WEEK) == Calendar.SATURDAY || cal.get(Calendar.DAY_OF_WEEK) == Calendar.SUNDAY) {
    cal.add(Calendar.DATE, 1);
}
System.out.println("Should end at " + cal.getTime());

哪个(基于前面的例子),输出......

Should end at Mon Feb 10 00:00:00 EST 2014

仔细查看Calendar了解更多详情

答案 1 :(得分:0)

java.time

现代方法使用由ThreeTen-Extra项目扩展的java.time类。

LocalDate类表示没有时间且没有时区的仅限日期的值。

LocalDate start = LocalDate.of( 2013 , Month.NOVEMBER , 9 ) ;

退一天,然后使用TemporalAdjuster中的org.threeten.extra.Temporals实施,请求下一个工作日(非星期六/星期日)。

LocalDate startAgain = 
    start.minusDays( 1 )
         .with( org.threeten.extra.Temporals.nextWorkingDay() ) ;

为下一个日期添加三个月。再次,退后一天,并要求下一个工作日。

LocalDate threeMonthsLaterWorkingDay = 
    startAgain.plusMonths( 3 )
              .minusDays( 1 )
              .with( org.threeten.extra.Temporals.nextWorkingDay() ) ;

关于java.time

java.time框架内置于Java 8及更高版本中。这些类取代了麻烦的旧legacy日期时间类,例如java.util.DateCalendar和& SimpleDateFormat

现在位于Joda-Timemaintenance mode项目建议迁移到java.time类。

要了解详情,请参阅Oracle Tutorial。并搜索Stack Overflow以获取许多示例和解释。规范是JSR 310

从哪里获取java.time类?

ThreeTen-Extra项目使用其他类扩展java.time。该项目是未来可能添加到java.time的试验场。您可以在此处找到一些有用的课程,例如IntervalYearWeekYearQuartermore