class ArrayComparator implements Comparator<Comparable[]> {
private final int columnToSort;
private final boolean ascending;
public ArrayComparator(int columnToSort, boolean ascending) {
this.columnToSort = columnToSort;
this.ascending = ascending;
}
public int compare(Comparable[] c1, Comparable[] c2) {
int cmp = c1[columnToSort].compareTo(c2[columnToSort]);
return ascending ? cmp : -cmp;
}
}
通过这种方式,您可以处理这些数组中任何类型的数据(只要它们是可比较的),并且可以按升序或降序对任何列进行排序。
String[][] data = getData();
Arrays.sort(data, new ArrayComparator(0, true));
PS:确保你检查和其他。ArrayIndexOutOfBounds
编辑:上述解决方案只有在您能够实际存储在第一列中,或者如果您的日期格式允许您对这些值使用纯字符串比较时才有用。否则,您需要将该字符串转换为日期,并且可以使用回调接口(作为常规解决方案)来实现这一点。以下是增强版本:java.util.Date
class ArrayComparator implements Comparator<Object[]> {
private static Converter DEFAULT_CONVERTER = new Converter() {
@Override
public Comparable convert(Object o) {
// simply assume the object is Comparable
return (Comparable) o;
}
};
private final int columnToSort;
private final boolean ascending;
private final Converter converter;
public ArrayComparator(int columnToSort, boolean ascending) {
this(columnToSort, ascending, DEFAULT_CONVERTER);
}
public ArrayComparator(int columnToSort, boolean ascending, Converter converter) {
this.columnToSort = columnToSort;
this.ascending = ascending;
this.converter = converter;
}
public int compare(Object[] o1, Object[] o2) {
Comparable c1 = converter.convert(o1[columnToSort]);
Comparable c2 = converter.convert(o2[columnToSort]);
int cmp = c1.compareTo(c2);
return ascending ? cmp : -cmp;
}
}
interface Converter {
Comparable convert(Object o);
}
class DateConverter implements Converter {
private static final DateFormat df = new SimpleDateFormat("yyyy.MM.dd hh:mm");
@Override
public Comparable convert(Object o) {
try {
return df.parse(o.toString());
} catch (ParseException e) {
throw new IllegalArgumentException(e);
}
}
}
此时,您可以使用以下命令对第一列进行排序:
Arrays.sort(data, new ArrayComparator(0, true, new DateConverter());
我跳过了对空值和其他错误处理问题的检查。
我同意这已经开始看起来像一个框架。:)
最后(希望)编辑:我现在才意识到您的日期格式允许您使用纯字符串比较。如果是这种情况,则不需要“增强版本”。