我已经很多年没有用 Java 编程了,但是我现在必须更改我前段时间写的一个程序。在这个程序中,我需要读取一个 QIF 文件并找到具有最大日期 (Dmm-dd-yyyy) 的 qif 记录。我无法让它在我的程序中工作,所以我编写了一个简单的测试来证明我遇到的问题。我认为还有其他方法可以做到这一点,例如列表和集合。但我仍然想知道为什么使用 SimpleDateFormat 不起作用。请注意,此方法会在输出中生成 7 月的最大值,但似乎忽略了所有 8 月的日期。
谢谢,迈克
导入 java.text.SimpleDateFormat;导入 java.util.Date;
class DateParser {
public static void main(String[] args) {
SimpleDateFormat sdf = new SimpleDateFormat("mm-dd-yyyy");
Date nextDate = null;
Date maxDate = null;
String nextStrDate = null;
String maxStrDate = null;
//Fill date array.
String date[] = {"07-14-2014","07-22-2014","07-31-2014",
"08-01-2014","08-04-2014","08-06-2014"};
try {
//Start with early maximum date.
maxDate = sdf.parse("01-01-1800");
// Find Max date in array.
for (int i=0; i<6; ++i) {
nextStrDate = date[i];
nextDate = sdf.parse(nextStrDate);
if(nextDate.after(maxDate)){
maxStrDate = nextStrDate;
maxDate = nextDate;
}
System.out.println( "Next Date = " + nextStrDate);
}
System.out.println("\nMax Date = " + maxStrDate);
} catch (Exception e) {
System.out.println("Got error:" + e);
}
}
}
OUTPUT
Next Date = 07-14-2014
Next Date = 07-22-2014
Next Date = 07-31-2014
Next Date = 08-01-2014
Next Date = 08-04-2014
Next Date = 08-06-2014
Max Date = 07-31-2014