Java 乔达时间-获得一年中的所有周
有没有办法把一年中所有的几周加上每周开始和结束的几天? (附) 类似这样(2012年): 第周:21 开始日期:2012年5月21日 完:2012年5月27日 谢谢你的帮助我从没用过乔达的时间。 我会这样做:Java 乔达时间-获得一年中的所有周,java,jodatime,date-arithmetic,Java,Jodatime,Date Arithmetic,有没有办法把一年中所有的几周加上每周开始和结束的几天? (附) 类似这样(2012年): 第周:21 开始日期:2012年5月21日 完:2012年5月27日 谢谢你的帮助我从没用过乔达的时间。 我会这样做: 创建一个具有weeknumber和两个日期时间(开始、结束)的类 创建此类的列表 迭代一年(每周),并将当前周保存在列表中 这就是我使用标准java日历api的方法。我不知道,也许乔达的时间稍微容易一点。试试这个: SimpleDateFormat df = new SimpleDateF
SimpleDateFormat df = new SimpleDateFormat("dd.MM.yyyy");
Period weekPeriod = new Period().withWeeks(1);
DateTime startDate = new DateTime(2012, 1, 1, 0, 0, 0, 0 );
DateTime endDate = new DateTime(2013, 1, 1, 0, 0, 0, 0 );
Interval i = new Interval(startDate, weekPeriod );
while(i.getEnd().isBefore( endDate)) {
System.out.println( "week : " + i.getStart().getWeekOfWeekyear()
+ " start: " + df.format( i.getStart().toDate() )
+ " ending: " + df.format( i.getEnd().minusMillis(1).toDate()));
i = new Interval(i.getStart().plus(weekPeriod), weekPeriod);
}
请注意,周数从52开始,然后从1到51,因为1月1日不是周日
如果要查看每个星期一和星期日的日期,请执行以下操作:
SimpleDateFormat df = new SimpleDateFormat("dd.MM.yyyy");
Period weekPeriod = new Period().withWeeks(1);
DateTime startDate = new DateTime(2012, 1, 1, 0, 0, 0, 0 );
while(startDate.getDayOfWeek() != DateTimeConstants.MONDAY) {
startDate = startDate.plusDays(1);
}
DateTime endDate = new DateTime(2013, 1, 1, 0, 0, 0, 0);
Interval i = new Interval(startDate, weekPeriod);
while(i.getStart().isBefore(endDate)) {
System.out.println("week : " + i.getStart().getWeekOfWeekyear()
+ " start: " + df.format(i.getStart().toDate())
+ " ending: " + df.format(i.getEnd().minusMillis(1).toDate()));
i = new Interval(i.getStart().plus(weekPeriod), weekPeriod);
}
Joda Time处于维护模式
仅供参考,该项目目前正在进行中,团队建议迁移到类。看
定义“周”
你可以用不同的方式定义一周
我想你指的是标准。第一周是一年中的第一个星期四,从星期一开始,以周为基础的一年有52周或53周。日历年结束或开始的几天可能会在另一个以周为基础的年份到来
java.time
现代方法使用类以及项目中的扩展
从三个额外的,使用类
获取基于周的年份中的周数,52或53
int weeks = start.lengthOfYear() ;
……或者
int weeks = ( start.is53WeekYear() ) ? 53 : 52 ;
一年中每周循环一次。对于每个YearWeek
,要求它为该周的开始和结束生成一个LocalDate
List<String> results = new ArrayList<>( weeks ) ;
YearWeek yw = start ;
for( int i = 1 , i <] weeks , i ++ ) {
String message = "Week: " + yw + " | start: " + yw.atDay( DayOfWeek.MONDAY ) + " | stop: " + yw.atDay( DayOfWeek.SUNDAY ) ;
results.add( message ) ;
// Prepare for next loop.
yw = yw.plusWeeks( 1 ) ;
}
列表结果=新的ArrayList(周);
YearWeek yw=开始;
对于(inti=1),我可能会使用数据库表而不是类,但您的想法是正确的。
List<String> results = new ArrayList<>( weeks ) ;
YearWeek yw = start ;
for( int i = 1 , i <] weeks , i ++ ) {
String message = "Week: " + yw + " | start: " + yw.atDay( DayOfWeek.MONDAY ) + " | stop: " + yw.atDay( DayOfWeek.SUNDAY ) ;
results.add( message ) ;
// Prepare for next loop.
yw = yw.plusWeeks( 1 ) ;
}