根据指定日期字符串 获取周一 和周日的日期
/**
* 根据指定日期获得一周的日期区间(周一和周日日期字符串表示)
* @param sdf
* @return
*/
public static String getThisWeekTimeInterval(String dateStr) {
SimpleDateFormat format = new SimpleDateFormat(pattern_date);
return getNWeekTimeInterval(1, dateStr,format);
}
/**
* 根据指定日期获得最近n周的日期区间(包含本周)
* @param n
* @param sdf
* @return
*/
public static String getNWeekTimeInterval(int n,String dateStr, SimpleDateFormat sdf) {
Date date = null;
try {
date = new SimpleDateFormat(pattern_date).parse(dateStr);
} catch (ParseException e) {
e.printStackTrace();
}
String beginDate = getFromToDate(sdf, date, n, 0, 0);
String endDate = getFromToDate(sdf, date, n, 1, 0);
return beginDate + "," + endDate;
}
/**
* 获取起止日期
* @param sdf 需要显示的日期格式
* @param date 需要参照的日期
* @param n 最近n周
* @param option 0 开始日期;1 结束日期
* @param k 0 包含本周 1 不包含本周
* @return
*/
public static String getFromToDate(SimpleDateFormat sdf, Date date, int n, int option, int k) {
Calendar calendar = Calendar.getInstance();
calendar.setTime(date);
int dayOfWeek = calendar.get(Calendar.DAY_OF_WEEK) - 1;
int offset = 0 == option ? 1 - dayOfWeek : 7 - dayOfWeek;
int amount = 0 == option ? offset - (n - 1 + k) * 7 : offset - k * 7;
calendar.add(Calendar.DATE, amount);
return sdf.format(calendar.getTime());
}
/**
* 获取起止日期
* @param sdf 需要显示的日期格式
* @param date 需要参照的日期
* @param n 最近n周
* @param option 0 开始日期;1 结束日期
* @param k 0 包含本周 1 不包含本周
* @return
*/
public static String getFromToDate(SimpleDateFormat sdf, Date date, int n, int option, int k) {
Calendar calendar = Calendar.getInstance();
calendar.setTime(date);
int dayOfWeek = calendar.get(Calendar.DAY_OF_WEEK) - 1;
int offset = 0 == option ? 1 - dayOfWeek : 7 - dayOfWeek;
int amount = 0 == option ? offset - (n - 1 + k) * 7 : offset - k * 7;
calendar.add(Calendar.DATE, amount);
return sdf.format(calendar.getTime());
}
//调用
String[] dateArray = DateHelper.getThisWeekTimeInterval(logDate).split(",");