根据日期计算属于第几周(周日是一周的第一天)
2014-12-16 10:37
225 查看
根据 日期计算属于第几周,见代码,重点是红色加粗代码,如果日期是下一年的第一周的时候的解决方案,如果谁有更好的方法,请不吝赐教
/**
* 根据日期计算属于第几周(周日是一周的第一天)
* @param date 格式 yyyy-MM-dd dispflg:0 返回yyyyww;1 返回yyyy年ww周
* @throws ParseException
* return 返回空表示异常,或日期为空
*/
public static String getWeekOfYear_Sunday_Normal(String date, String pattern, String dispflg) {
if (date == null)
return "";
if (pattern == null)
pattern = DATE_FORMAT_YYYY_MM_DD;
try {
SimpleDateFormat df = new SimpleDateFormat(pattern);
Calendar cal = Calendar.getInstance();
cal.setFirstDayOfWeek(Calendar.SUNDAY); // 设置每周的第一天为星期日
//cal.set(Calendar.DAY_OF_WEEK, Calendar.MONDAY);// 每周从周一开始
cal.setMinimalDaysInFirstWeek(1); // 设置每周最少为1天
cal.setTime(df.parse(date));
int year = cal.get(Calendar.YEAR);//获得当前年
int month = cal.get(Calendar.MONTH);//获得当前月
int week = cal.get(Calendar.WEEK_OF_YEAR);//获得周数
if (month + 1 == 12 && week == 1) {
year += 1;//如果当前月是12月并且周数是1,作为明年的第一周
}
if (dispflg.equals("0")) {
return year + "" + (week < 10 ? "0" + week : week);//返回"yyyyww"格式
} else if (dispflg.equals("1")) {
return year + "年" + (week < 10 ? "0" + week : week) + "周";//返回"yyyy年ww周"格式
}
} catch (Exception e) {
e.printStackTrace();
}
return "";
}
/**
* 根据日期计算属于第几周(周日是一周的第一天)
* @param date 格式 yyyy-MM-dd dispflg:0 返回yyyyww;1 返回yyyy年ww周
* @throws ParseException
* return 返回空表示异常,或日期为空
*/
public static String getWeekOfYear_Sunday_Normal(String date, String pattern, String dispflg) {
if (date == null)
return "";
if (pattern == null)
pattern = DATE_FORMAT_YYYY_MM_DD;
try {
SimpleDateFormat df = new SimpleDateFormat(pattern);
Calendar cal = Calendar.getInstance();
cal.setFirstDayOfWeek(Calendar.SUNDAY); // 设置每周的第一天为星期日
//cal.set(Calendar.DAY_OF_WEEK, Calendar.MONDAY);// 每周从周一开始
cal.setMinimalDaysInFirstWeek(1); // 设置每周最少为1天
cal.setTime(df.parse(date));
int year = cal.get(Calendar.YEAR);//获得当前年
int month = cal.get(Calendar.MONTH);//获得当前月
int week = cal.get(Calendar.WEEK_OF_YEAR);//获得周数
if (month + 1 == 12 && week == 1) {
year += 1;//如果当前月是12月并且周数是1,作为明年的第一周
}
if (dispflg.equals("0")) {
return year + "" + (week < 10 ? "0" + week : week);//返回"yyyyww"格式
} else if (dispflg.equals("1")) {
return year + "年" + (week < 10 ? "0" + week : week) + "周";//返回"yyyy年ww周"格式
}
} catch (Exception e) {
e.printStackTrace();
}
return "";
}
相关文章推荐
- 根据日期计算出周一和周日
- 根据日期计算当前日期所在周是日期所在年份的第几周
- 根据当前时间计算周次!(每年的第一天属于第一周 C#实现)
- 根据当前第几周,获取这一周的日期,(问题关键是获取该月份的第几天即可)
- Domino计算当前日期是这一年的第几周,以及计算任意一周都分别是哪七天?
- 计算特定日期的前一天和后一天,根据输入的月,日获取该月日属于什么季节
- 根据具体日期计算是一年的第几周和当月的第几周
- 日期类,根据日期计算是本年度的第几天,第几周,星期几
- 以周一为一周的第一天来计算当前时间是本月的第几周
- T-SQL 2 Tips: 1.计算任意两日期之间的"周一"到"周日"分别各有几个! 2.根据出生日期计算精确年龄!
- 计算当前日期是第几周,周一算第一天
- T-SQL 2 Tips: 1.计算任意两日期之间的"周一"到"周日"分别各有几个! 2.根据出生日期计算精确年龄!
- 根据当前传入日期计算该日期所在星期的周一和周日
- 根据传入的年份和月份获取该月属于本年的第几周和每周的开始和结束日期
- T-SQL2Tips:1.计算任意两日期之间的&quot;周一&quot;到&quot;周日&quot;分别各有几个!2.根据出生..
- Java 根据指定日期计算所在周的周一和周日
- 一个有意思的问题:如何根据一年中的第几周,查询出它周六和周日对应的日期
- mysql 根据指定日期取 周一至周日 本月第一天 最后一天
- Java 根据指定日期计算所在周的周一和周日
- 日期类,根据日期计算是本年度的第几天,第几周,星期几(改进版)