我有一个包含"2013-7-13 \n 12 hour(s) 23 minute(s) "
这类记录的arraylist。我怎么能只按日期排序。
一段代码:
String date1 = c.getString(c.getColumnIndex(TabProDB.KEY_DATE) );
String time1 = c.getString(c.getColumnIndex(TabProDB.KEY_TIME) );
String date_time1 = date1 + "\n" +time1;
Toast.makeText(History.this, date_time1, Toast.LENGTH_SHORT).show();
listItems.add(date_time1);
答案 0 :(得分:2)
创建您自己的Comparator<String>
实现,如下所示:
请注意,没有错误检查,只是为了告诉您如何做到这一点。
public static void main(String[] args) {
List<String> strings =
Arrays.asList("2013-7-13 \n 12 hour(s) 23 minute(s)",
"2013-7-10 \n 12 hour(s) 23 minute(s)");
Collections.sort(strings, new Comparator<String>() {
@Override
public int compare(String o1, String o2) {
SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
Date date1;
Date date2;
try {
date1 = format.parse(o1.split(" ")[0]);
date2 = format.parse(o2.split(" ")[0]);
} catch (ParseException e) {
throw new IllegalArgumentException("Could not parse date!", e);
}
return date1.compareTo(date2);
}
});
System.out.println(strings);
}
答案 1 :(得分:1)
虽然你应该通过将日期和时间作为类对象传递来遵循面向对象的样式......并且在这个类中使用Arraylist。 无论如何......这段代码可能会帮助你!
记住字符串比较和日期和时间比较是两个 不同的东西,你也可以根据你的需要重构代码
public class MyComparator implements Comparator<String> {
@Override
public int compare(String o1, String o2) {
int result = o1.compareTo(o2);
return result;
}
}
Now use Collection.sort method
List<String> dateTimeList = new ArrayList<String>
Collections.sort(dateTimeList, new MyComparator());
答案 2 :(得分:0)
Array.sort可以传递自定义比较器。如果您知道所有字符串格式完全相同的事实,只需根据子字符串创建比较器。
您也可以实现自己的排序,但这并不理想,因为Java已经提供了功能。
答案 3 :(得分:0)
你可以尝试做的步骤......
- &gt;如果你确定&#34; \ n&#34;每个条目中都有比较y ,然后只使用 org.apache.commons.lang.StringUtils.substringBefore(String,String)说明每个条目获取日期部分X 强>
- &GT;下一步是使用 java.text.SimpleDateFormat (yyyy-mm-dd)
将x解析为日期- &GT;然后,您可以使用任何可以包含键和值对的集合对象,其中键是x和值y(使用 TreeMap ,这可以自动对值进行排序。)
此方法存在问题:如果x部分在您的数组的多个条目中很常见,则此方法无效。
尝试运行此代码。最后一个print语句将为您提供排序结果。地图中的值是您正在寻找的。 p>
class TestClass {
public void checkThis() throws ParseException {
String[] sampleValues = new String[3];
sampleValues[0]= "2013-7-13 \n 12 hour(s) 23 minute(s) ";
sampleValues[1]= "2013-8-14 \n 12 hour(s) 23 minute(s) ";
sampleValues[2]= "2013-5-16 \n 12 hour(s) 23 minute(s) ";
System.out.println("--> before"+ sampleValues);
String x= null;
Date date =null;
Map<Date, String> map = new TreeMap<Date, String>();
SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd");
for (String y : sampleValues) {
x = StringUtils.substringBefore(y, " \n");
date= formatter.parse(x);
map.put(date, y);
}
System.out.println(map.keySet());
}
}
答案 4 :(得分:0)
第一步
将您的String
解析为实际的Date
对象:
final String s = "2013-7-13 \n 12 hour(s) 23 minute(s)";
final SimpleDateFormat sdf = new SimpleDateFormat("yyyy-M-dd \n hh 'hour(s)' 23 'minute(s)'");
final Date d = sdf.parse(s);
不要将日期存储为字符串。
第二步
将所有新的Date
放入List
并致电Collections.sort
。
以后您可以使用相同的SimpleDateFormat
(或完全不同的)将Date
格式化回String
:
final String form = sdf.format(d);
System.out.println(form);
输出:
2013-7-13 \ n 12小时23分钟