如何将时间与另外两个时间进行比较?

时间:2013-03-22 07:13:45

标签: android time

令人困惑..就像我们比较时间一样,绝对不建议使用字符串......但如果它的格式为(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. 我该怎么做?在时间格式中,是否大于(&gt;)并小于(&lt;)

3 个答案:

答案 0 :(得分: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)

答案 1 :(得分:0)

SimpleDateFormat df=new SimpleDateFormat("hh:mm:ss");             
Date d1=df.parse(dateToPars); 

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

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

答案 2 :(得分: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();
        }

    }