2

一直很困惑..就像我们在比较时间一样,绝对不推荐使用字符串...但是如果它的格式是(HH:mm:ss)。我应该如何比较它们来做某事?

例如:目标1:9:00:00 目标2:23:00:00

如何在输入大于 Target1 且小于 Target2 的情况下进行比较逻辑?

if(input > Target1 && input < Target2){
  //do statement A
}else{
  //do statement B
}

所以如果我的输入时间是 10:00:00,它应该运行语句 A,如果输入时间是 23:01:00,它应该运行语句 B 我应该怎么做?大于 (>) 且小于 (<) 的时间格式是否合适?

4

3 回答 3

1

给定它们作为字符串,您可以将它们从 SimpleDateFormat 转换为 Date 对象。

SimpleDateFormat sdf = new SimpleDateFormat("HH:mm:ss");

最简单的方法是通过执行将它们转换为毫秒数

long time1 = sdf.parse(Target1).getTime();
long time2 = sdf.parse(Target2).getTime();
long inputTime = sdf.parse(input).getTime();

这样,您实际上是在进行整数比较,您可以忘记所有日期时间业务。

if(inputTime > time1 && inputTime < time2)
于 2013-03-22T07:17:07.340 回答
0

您可以使用日历函数.getTimeInMillis()计算差异,并获得2个不同时间的差异,这里您只需在日历中设置您的特定时间并进行比较

try{
            Calendar calender = Calendar.getInstance();
            Calendar calDb = Calendar.getInstance();
            Calendar matchd = Calendar.getInstance();

            mYear = calender.get(Calendar.YEAR);
            mMonth = calender.get(Calendar.MONTH);
            mDay = calender.get(Calendar.DAY_OF_MONTH);

            mendYear = calDb.get(Calendar.YEAR);
            mendMonth = calDb.get(Calendar.MONTH);
            mendDay = calDb.get(Calendar.DAY_OF_MONTH);    
                       // Here you can change day values        
                    calDb.set(Calendar.DAY_OF_MONTH, mDay-1);

            strbeforedate = mDateFormat.format(calDb.getTime());
            curentdate = mDateFormat.format(calender.getTime());

            calDb.setTime(mDateFormat.parse(strbeforedate));
            calender.setTime(mDateFormat.parse(curentdate));



            String mydate = "2013.03.14 03:11";
            String mdatetime = "";

            deletepath =  new ArrayList<String>();          

                try{
                    // here your matching goes and pass date here 

                     matchd.setTime(mDateFormat.parse(mdatetime));
                     long diff = calDb.getTimeInMillis() - calender.getTimeInMillis();
                     long matchdiff = matchd.getTimeInMillis() - calender.getTimeInMillis();
                        if(diff < matchdiff){

                                     // do your work here
                        }else{

                         // do your else work here

                        }
                }catch(Exception e){
                    e.printStackTrace();
                }                   
        }

        }catch(Exception e){
            e.printStackTrace();
        }

    }
于 2013-03-22T08:04:49.527 回答
0
SimpleDateFormat df=new SimpleDateFormat("hh:mm:ss");             
Date d1=df.parse(dateToPars); 

d1.after(otherTimeYouWantTocompare);  OR 
d1.before(otherTimeYouWantTocompare); 

但是您必须以上述格式提供时间

于 2013-03-22T07:20:35.023 回答