我想在一列中按日期对 Jtable 进行排序,但仅以 dd-MM-yyyy 格式显示日期。所以所有条目都是相同的,只是在不可见的秒数上有所不同。
我有一个 TableModel 使用以下方法获取数据:
@Override
public Object getValueAt(int row, int col) {
Object[][] tableData = new Object[rowDataMap.keySet().size()][1];
int index = 0;
for (Long key : pane.nqm_messages.keySet())
{
Date date = rowDataMap.get(key);
SimpleDateFormat form = new SimpleDateFormat("dd-MM-yyyy");
String outputDate = form.format(date);
tableData[index][0] = outputDate;
index++;
}
return tableData[row][col];
}
这是我想要对行进行排序的 TableRowSorter:
TableRowSorter<TableModel> sorter = new TableRowSorter<TableModel>(model);
List<SortKey> keys = new ArrayList<SortKey>();
SortKey sortKey;
sorter.setComparator( 0, new Comparator<String>() {
@Override
public int compare(String s1, String s2) {
//Sort dd-MM-yyyy
}
});
如果我这样做,我无法对其进行排序,因为字符串是 obv。全部都一样。当我像这样直接使用日期对象时
表数据[索引][0] = 日期
我不知道如何以正确的格式显示它,但可以进行排序。
我怎样才能实现两者?