書式(MM/DD/YYYY)の日付フィールド(文字列)はサービスコールから取得しています。 私の要件は、日付でリストをソートし、最新の日付でレコードを表示することです。MM/DD/YYYYで日付順に並べ替える形式
私は以下のコードを試しました。しかし、最新の日付までにレコードを表示することはできません。
public class Test {
public static void main(String[] args) {
List<Opportunity> oppList = new ArrayList<Opportunity>();
Opportunity opp1 = new Opportunity();
opp1.setName("opp1");
opp1.setExpires("11/07/2016");
Opportunity opp2 = new Opportunity();
opp2.setName("opp2");
opp2.setExpires("11/08/2016");
oppList.add(opp1);
oppList.add(opp2);
List<Opportunity> opplist=sortOpportunitiesByDate(oppList);
/*Collections.sort(oppList);*/
for(int i=0; i<opplist.size(); i++){
System.out.println("Opportunity Data>>>"+opplist.get(i).getExpires());
}
}
private static List<Opportunity> sortOpportunitiesByDate(List<Opportunity> opportunities) {
Collections.sort(opportunities, new Comparator<Opportunity>() {
public int compare(Opportunity o1, Opportunity o2) {
DateFormat format = new SimpleDateFormat("MM/DD/YYYY",Locale.US);
Date date1 = null;
Date date2 = null;
try {
date1=format.parse(o1.getExpires());
date2=format.parse(o2.getExpires());
} catch (ParseException e) {
e.printStackTrace();
}
return date1.compareTo(date2);
}
});
return opportunities;
}
}
実際の出力:
Opportunity Date>>>11/07/2016
Opportunity Date>>>11/08/2016
予想される出力:
Opportunity Date>>>11/08/2016
Opportunity Date>>>11/07/2016
日に動作しますが、関係なく、あなたがフォーマットされたかの日付ではありませんので、あなたはそれをソートするために、その後、比較する必要があります。.. –
試してみますcompareTo()をdate2を使用して呼び出し、date1を渡します。 –
私もその方法を試しました。それは動作しません。 – String