根据某一固定日期获取 该日期所在年度的周,该日期所在周 周一和周日的 具体日期
2017-06-11 18:28
288 查看
/**
*meteor
* 根据某一固定日期获取 该日期所在年度的周,该日期所在周 周一和周日的 具体日期
* @param date
* @return
* map(date:传入的时间,week:第几周,monday:周一的日期[yyyy-MM-dd],sunday:周日的日期[yyyy-MM-dd])
*/
public static Map<String, String> getMapByDate(Date date){
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
Map<String, String> map = new HashMap<String, String>();
Calendar cal = Calendar.getInstance();
cal.setTime(date);
map.put("date", sdf.format(cal.getTime()));
int dayWeek = cal.get(Calendar.DAY_OF_WEEK);
if (1 == dayWeek) {
cal.add(Calendar.DAY_OF_MONTH, -1);
}
cal.setFirstDayOfWeek(Calendar.MONDAY);
map.put("week", cal.get(Calendar.WEEK_OF_YEAR) + "");
int day = cal.get(Calendar.DAY_OF_WEEK);
cal.add(Calendar.DATE, cal.getFirstDayOfWeek() - day);
map.put("monday", sdf.format(cal.getTime()));
cal.add(Calendar.DATE, 6);
map.put("sunday", sdf.format(cal.getTime()));
return map;
}
/**
* 该日期所在周 周一的 具体日期
* @param date
* @return
*/
public static Date getMondayOfWeekDate(Date date){
java.text.SimpleDateFormat sdf = new java.text.SimpleDateFormat("yyyy-MM-dd");
Map<String, String> map = getMapByDate(date);
Date reDate = null ;
try {
reDate = sdf.parse(map.get("monday"));
} catch (ParseException e) {
}
return reDate;
}
/**
* 该日期所在周 周日的 具体日期
* @param date
* @return
*/
public static Date getSundayOfWeekDate(Date date){
java.text.SimpleDateFormat sdf = new java.text.SimpleDateFormat("yyyy-MM-dd");
Map<String, String> map = getMapByDate(date);
Date reDate = null ;
try {
reDate = sdf.parse(map.get("sunday"));
} catch (ParseException e) {
}
return reDate;
}
/**
* 获取 该日期所在年度的周
* @param date
* @return
*/
public static String getWeekOfYearStr(Date date){
Map<String, String> map = getMapByDate(date);
String year = map.get("sunday").substring(0,4);
String week = map.get("week");
int strLen = week.length();
if (strLen < 2) {
while (strLen < 2) {
StringBuffer sb = new StringBuffer();
sb.append("0").append(week);
week = sb.toString();
strLen = week.length();
}
}
return year+week;
}
*meteor
* 根据某一固定日期获取 该日期所在年度的周,该日期所在周 周一和周日的 具体日期
* @param date
* @return
* map(date:传入的时间,week:第几周,monday:周一的日期[yyyy-MM-dd],sunday:周日的日期[yyyy-MM-dd])
*/
public static Map<String, String> getMapByDate(Date date){
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
Map<String, String> map = new HashMap<String, String>();
Calendar cal = Calendar.getInstance();
cal.setTime(date);
map.put("date", sdf.format(cal.getTime()));
int dayWeek = cal.get(Calendar.DAY_OF_WEEK);
if (1 == dayWeek) {
cal.add(Calendar.DAY_OF_MONTH, -1);
}
cal.setFirstDayOfWeek(Calendar.MONDAY);
map.put("week", cal.get(Calendar.WEEK_OF_YEAR) + "");
int day = cal.get(Calendar.DAY_OF_WEEK);
cal.add(Calendar.DATE, cal.getFirstDayOfWeek() - day);
map.put("monday", sdf.format(cal.getTime()));
cal.add(Calendar.DATE, 6);
map.put("sunday", sdf.format(cal.getTime()));
return map;
}
/**
* 该日期所在周 周一的 具体日期
* @param date
* @return
*/
public static Date getMondayOfWeekDate(Date date){
java.text.SimpleDateFormat sdf = new java.text.SimpleDateFormat("yyyy-MM-dd");
Map<String, String> map = getMapByDate(date);
Date reDate = null ;
try {
reDate = sdf.parse(map.get("monday"));
} catch (ParseException e) {
}
return reDate;
}
/**
* 该日期所在周 周日的 具体日期
* @param date
* @return
*/
public static Date getSundayOfWeekDate(Date date){
java.text.SimpleDateFormat sdf = new java.text.SimpleDateFormat("yyyy-MM-dd");
Map<String, String> map = getMapByDate(date);
Date reDate = null ;
try {
reDate = sdf.parse(map.get("sunday"));
} catch (ParseException e) {
}
return reDate;
}
/**
* 获取 该日期所在年度的周
* @param date
* @return
*/
public static String getWeekOfYearStr(Date date){
Map<String, String> map = getMapByDate(date);
String year = map.get("sunday").substring(0,4);
String week = map.get("week");
int strLen = week.length();
if (strLen < 2) {
while (strLen < 2) {
StringBuffer sb = new StringBuffer();
sb.append("0").append(week);
week = sb.toString();
strLen = week.length();
}
}
return year+week;
}
相关文章推荐
- 根据当前日期获得所在周的日期区间(周一和周日日期),一个月有多少天
- mysql根据日期获取周一周日
- asp.net 根据当前时间获取本周、上周、下周的周一、周日日期
- Java 根据指定日期计算所在周的周一和周日
- 根据当前传入日期计算该日期所在星期的周一和周日
- Java 根据指定日期计算所在周的周一和周日
- java获取当前时间所在一周的周一和周日日期
- SQL方法~获取给定时间所在周一至周日的日期范围
- 获取指定日期所在一周的时间范围(周一00:00:00---周日 23:59:59)
- java获取当前时间所在一周的周一和周日日期
- mysql 获取当前日期 所在周的周一和周日
- 通过某日期得到该日期所在的一周的周一和周日的日期
- PHP根据IP地址获取所在城市具体实现
- PHP根据IP地址获取所在城市具体实现
- JS获取本周周一 周日日期、本季度、本月、上月的开端日期、停止日期
- java 获取上一周周一到周日的日期
- java实现获取当前日期所在的四个周的周日的功能,其中当前日期的周日是第三个,第四个是下周周日
- T-SQL 2 Tips: 1.计算任意两日期之间的"周一"到"周日"分别各有几个! 2.根据出生日期计算精确年龄!
- Java获取给定时间取得周一和周日日期
- IOS 根据日期,获取该日期所在周,月,年的开始日期,结束日期 的方法