3

我有一个问题,日期比较。我有一个来自 TextView 的日期(通常存储在 SQLite 文本字段中)。TextView rowduedate 带有一个日期,其值为:“2012/10/01 15:16” 所以它不是空的。但是我在 LogCat 中收到以下错误:

11-01 15:16:55.445: E/AndroidRuntime(783): FATAL EXCEPTION: main
11-01 15:16:55.445: E/AndroidRuntime(783): java.lang.NumberFormatException: Invalid   long: ""
11-01 15:16:55.445: E/AndroidRuntime(783):  at   java.lang.Long.invalidLong(Long.java:125)
11-01 15:16:55.445: E/AndroidRuntime(783):  at java.lang.Long.parseLong(Long.java:346)
11-01 15:16:55.445: E/AndroidRuntime(783):  at java.lang.Long.parseLong(Long.java:319)
11-01 15:16:55.445: E/AndroidRuntime(783):  at com.android.demo.notepad3.Notepadv3$1.setViewValue(Notepadv3.java:100)

这是代码:

TextView dueDate = (TextView) view.findViewById(R.id.rowduedate);
String due = (String) dueDate.getText().toString();

if(due!=null){
Long longDue = Long.parseLong(due);
String now = new Date().toString();
Long longNow = Long.parseLong(now);

if(longDue <= longNow){

       dueDate.setTextColor(Color.RED);
}               
}
4

3 回答 3

3

您需要告诉您的代码日期的格式,以便从中提取时间。

String strDate = "2007-12-25";
SimpleDateFormat Formatter = new SimpleDateFormat("yyyy/MM/dd");
Date myDate    = Formatter.parse(strDate);
于 2012-11-01T15:28:41.747 回答
1

看来您正在尝试解析一个空字符串,请注意这一点。

假设您的 dueDate:TextView 包含以下格式的有效日期“2012/10/01 15:16”:

long due = new SimpleDateFormat("yyyy/MM/dd HH:mm").parse(dueDate.getText().toString()).getTime();

if (due <= System.currentTimeMillis()) 
    dueDate.setTextColor(Color.RED);

这应该有帮助,

于 2012-11-01T15:54:10.000 回答
0

不要通过将日期字符串解析为Long

这是比较日期值的方法。核实

TextView dueDate = (TextView) view.findViewById(R.id.rowduedate);
String due = (String) dueDate.getText().toString();
SimpleDateFormat parser=new SimpleDateFormat("yyyy/MM/dd HH:mm");
Date d = null;
Date now = new Date();
if(due!=null){
try {
  d = parser.parse(due);
} catch (ParseException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
}
if(d.before(now){

       dueDate.setTextColor(Color.RED);
}               
}
于 2012-11-02T03:48:11.040 回答