java获取一年的周数和间隔天数

 import java.text.ParseException;
 import java.text.SimpleDateFormat;
 import java.util.*;

 public class Test {

     private static Date deformatDatetime(String strDate, String fmt) {
         try {
             if (fmt == null) {
                 return (new SimpleDateFormat("yyyy-MM-dd HH:mm:ss",
                         java.util.Locale.ENGLISH)).parse(strDate);
             } else {
                 return (new SimpleDateFormat(fmt, java.util.Locale.ENGLISH))
                         .parse(strDate);
             }
         } catch (ParseException e) {
             // TODO Auto-generated catch block
             e.printStackTrace();
             return null;
         }
     }
     private static String datetimeToString(Date dt, String fmt) {
         if (fmt == null) {
             return (new SimpleDateFormat("yyyy-MM-dd HH:mm:ss",
                     java.util.Locale.ENGLISH)).format(dt);
         } else {
             return (new SimpleDateFormat(fmt, java.util.Locale.ENGLISH))
                     .format(dt);
         }
     }
     private static class DateRange{
         public Date startDate;
         public Date endDate;
         public DateRange(){

         }
         public DateRange(Date dt1,Date dt2){
             startDate=dt1;
             endDate=dt2;
         }
     }
     /**
      * 根據年份獲得該年所有周次及每周的開始-結束日期
      * @param pvnYear
      * @return
      */
     private static LinkedHashMap<Integer,DateRange> getWeeksDetByYear(int pvnYear){
         LinkedHashMap<Integer, DateRange> lvRet=new LinkedHashMap<Integer,DateRange>();
         Calendar lvCal=Calendar.getInstance();
         lvCal.setFirstDayOfWeek(Calendar.MONDAY);

         Date lvDt=deformatDatetime(String.valueOf(pvnYear)+"-01-01 00:00:00", null);
         lvCal.setTime(lvDt);
         int lvWeek=1;
         while (true) {
             lvCal.set(Calendar.DAY_OF_WEEK, lvCal.getFirstDayOfWeek()); // Monday
             Date lvFirstDt=lvCal.getTime();
             if (lvFirstDt.getYear()+1900<pvnYear){
                 lvFirstDt=lvDt;
             }
             if (lvFirstDt.getYear()+1900>pvnYear) break;
             lvCal.set(Calendar.DAY_OF_WEEK, lvCal.getFirstDayOfWeek()+6); // Sunday?
             Date lvLastDt=lvCal.getTime();
             if (lvLastDt.getYear()+1900>pvnYear){
                 lvLastDt=deformatDatetime(String.valueOf(pvnYear+1)+"-01-01 00:00:00", null);
                 lvCal.setTime(lvLastDt);
                 lvCal.add(Calendar.DAY_OF_YEAR, -1);
                 lvLastDt=lvCal.getTime();
             }
             lvRet.put(Integer.valueOf(lvWeek), new DateRange(lvFirstDt, lvLastDt));
             lvWeek++;
             lvCal.add(Calendar.WEEK_OF_YEAR, 1);
         }
         return lvRet;
     }
     public static void main(String[] args) throws  Exception{
         SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
         LinkedHashMap<Integer,DateRange>  lvRet=getWeeksDetByYear(2011);
         for (Map.Entry<Integer, DateRange> item:lvRet.entrySet()){
             String startDate = datetimeToString(item.getValue().startDate,"yyyy-MM-dd");
             String endDate = datetimeToString(item.getValue().endDate,"yyyy-MM-dd");
             Date date1 = format.parse(startDate);
             Date date2 = format.parse(endDate);
             int diff = differentDays(date1,date2);
             System.out.println(String.format("Week: %d, %s - %s", item.getKey(),datetimeToString(item.getValue().startDate,"yyyy-MM-dd"),
                     datetimeToString(item.getValue().endDate,"yyyy-MM-dd"))+" ----------"+diff);
         }
     }

     public static int differentDays(Date date1,Date date2)
     {
         Calendar cal1 = Calendar.getInstance();
         cal1.setTime(date1);

         Calendar cal2 = Calendar.getInstance();
         cal2.setTime(date2);
         int day1= cal1.get(Calendar.DAY_OF_YEAR);
         int day2 = cal2.get(Calendar.DAY_OF_YEAR);

         int year1 = cal1.get(Calendar.YEAR);
         int year2 = cal2.get(Calendar.YEAR);
         if(year1 != year2)   //同一年
         {
             int timeDistance = 0 ;
             for(int i = year1 ; i < year2 ; i ++)
             {
                 if(i%4==0 && i%100!=0 || i%400==0)    //闰年
                 {
                     timeDistance += 366;
                 }
                 else    //不是闰年
                 {
                     timeDistance += 365;
                 }
             }

             return timeDistance + (day2-day1) ;
         }
         else    //不同年
         {
             return day2-day1;
         }
     }
 }

java获取一年的周数和间隔天数的更多相关文章

  1. java获取当前上一周、上一月、上一年的时间

    SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); Calendar c = Calend ...

  2. C# 获取当前日期当年的周数

    这几天跨年,项目上遇到了一个周数计算的问题. 2016年的元旦是周五开始的,之前系统计算的是属于15年的第53个周,但是年份已经到了16年了. 公司要求从1月1号周五开始算作16年的第一个周,今天1月 ...

  3. JAVA获取当前日期时间所在周的周一和周日日期

    /** * 获取当前时间所在周的周一和周日的日期时间 * @return */ public static Map<String,String> getWeekDate() { Map&l ...

  4. Java获取当前第几周【转】

    本文copy自:http://swxzqsd.blog.sohu.com/156208509.html 作者:camelcanoe String today = "2010-01-11&qu ...

  5. java获取当前日期所在的周的周一,并以周一为一周开始

    public String getMonday(String date) { if (date == null || date.equals("")) { System.out.p ...

  6. java获取本月开始时间和结束时间、上个月第一天和最后一天的时间以及当前日期往前推一周、一个月

    import java.text.SimpleDateFormat; import java.util.Calendar; import java.util.Date; import java.uti ...

  7. Java获取某年某周的第一天

    Java获取某年某周的第一天 1.设计源码 FirstDayOfWeek.java: /** * @Title:FirstDayOfWeek.java * @Package:com.you.freem ...

  8. sql 中,如何获取两个日期之前月数、周数、天数

    1.获取两个日期之间的月数.周数.天数语法 --1.获取两个日期之间的月数.周数.天数 --1.1)声明参数 ) ) --1.2)获取两个日期直接的月数 select DATEDIFF(MM,@sta ...

  9. Java获取日期属于当年第几周

    String today = "2013-01-14"; SimpleDateFormat format = new SimpleDateFormat("yyyy-MM- ...

随机推荐

  1. 通过iostat来查看linux硬盘IO性能|实例分析

    iostat查看linux硬盘IO性能 rrqm/s: 每秒进行 merge 的读操作数目.即 delta(rmerge)/s wrqm/s: 每秒进行 merge 的写操作数目.即 delta(wm ...

  2. MySQL报错: Character set ‘utf8mb4‘ is not a compiled character set and is not specified in the ‘/usr/share/mysql/charsets/Index.xml‘ file

    由于日常程序使用了字符集utf8mb4,为了避免每次更新时,set names utf8mb4,就把配置文件改了,如下: [root@~]# vim /etc/my.cnf #my.cnf [clie ...

  3. IDEA的debug操作

  4. 装饰器实现session登陆 验证功能

    装饰器 登陆验证功能 1.装饰器模板 from django.shortcuts import render, redirect, HttpResponse from django.conf impo ...

  5. 解决ASP.NET MVC(post数据)Json请求太大,无法反序列化,而报【远程服务器返回错误: (500) 内部服务器错误】

    1. 修改web.config文件可以改变这个默认值(上传1个G) <configuration> <system.web> <httpRuntime maxReques ...

  6. 【C#】wpf中的xmlns命名空间为什么是一个网址,代表了什么意思(转载)

    原文:https://blog.csdn.net/catshitone/article/details/71213371 新建一个wpf的项目,我们先来看下它默认的命名空间都是哪些? 可以看到xmln ...

  7. [转] Node.js使用MongoDB3.4+Access control is not enabled for the database解决方案

    今天使用MongoDB时遇到了一些问题 建立数据库连接时出现了warnings 出现这个警告的原因是新版本的MongDB为了让我们创建一个安全的数据库 必须要进行验证 后来在外网找到了答案 解决方案如 ...

  8. T4模版自动生成MSSQL实体类

    在Model层建立ModelAuto.ttinclude文件 <#@ assembly name="System.Core"#> <#@ assembly nam ...

  9. sdoi2017苹果树

    题解: 非常奇妙的一题.. 没有免费操作我都不会$nk$....考试打个暴力就可以走人了 树上有依赖背包问题的正确做法是(为啥我之前学的不是这样的啊) 按照后续遍历做背包 做到一个点的时候 枚举它选不 ...

  10. WPF中矢量图制作和引用

    WPF程序有时需要适配不同大小的屏幕,图片是像素图的话,拉伸之后会变模糊,影响美观度,因此可以考虑使用矢量图.网上找到了相应的介绍:http://learnwpf.com/post/2006/06/0 ...