前言:
系统上线有一阵子,可是最近刚发现统计部分里数据有遗漏的情况,这个时候,以前统计的数据要重新统计一遍,由于系统中统计是按每天定时做的,所以需要前一个多月里所有的数据重新统计一遍,这个时候有两种办法:
1、手动的将过往每天的数据重新统计一遍
2、给出起、止时间,循环每一天进行自动统计。
很明显,做为程序猿,第一个想到的就是用程序来实现了...
假如我们给出的起止时间是:'2013-11-11',截止时间用今天吧,'2014-01-10',我们的任务是在task方法里,task要接收的参数正是每一天的字符串格式,下边给出简单的实现:
public void doIt() throws Exception {
try {
Calendar startTime = Calendar.getInstance();
SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
startTime.setTime(format.parse("2013-11-11"));
Calendar endTime = Calendar.getInstance();
endTime.setTime(format.parse("2014-01-10"));
while(startTime.before(endTime)) {
System.out.println(format.format(startTime.getTime()));
String time = format.format(startTime.getTime());
task(time);
startTime.add(Calendar.DAY_OF_MONTH, 1);
}
}catch(Exception e) {
e.printStackTrace();
}
}
程序很简单,不用解释了...
程序中的startTime.add(Calendar.DAY_OF_MONTH,1)代表递增一天,这样就到了下一天,如此循环,一直可以做到'2014-01-09',为什么才是09?,当然是因为今天还没有过完了?哈哈,开玩笑的,那是因为,我们截止到9号的下一天就是10号了啊,startTime变成10号的时候,while中的条件已经成为了false了。
虽然有人发过这样的帖子,但由于是项目中用到的,还是重新写一下,用于自己笔记吧。