在 Java 中,是否可以在 JTable 中通过查找包含在该行中的指定值来获取该行的索引?我正在使用自定义表格模型。例如,考虑一个具有三列和三行的表:
Row 1 = A, B, C
Row 2 = D, E, F
Row 3 = G, H, I
如果我只知道表中某处有一个值“F”,我如何找出值“F”所在行的索引?
如果表模型可用,一种蛮力的方法是按行和列循环并将给定值(例如,'F')与getValueAt(row, column)
. 示例代码:
int getRowByValue(TableModel model, Object value) {
for (int i = model.getRowCount() - 1; i >= 0; --i) {
for (int j = model.getColumnCount() - 1; j >= 0; --j) {
if (model.getValueAt(i, j).equals(value)) {
// what if value is not unique?
return i;
}
}
}
}
private int returnRowIndexForValue(final String value) {
for (int i = 1; i <= table.getRowCount(); i++)
for(int j = 1; j <= table.getColumnCount(); j++)
if (table.getValueAt(i, j).equals(value))
return i;
}
以防万一如果有multiple rows
包含该值的,则返回返回Integer List.
private List<Integer> getRowIndexesOfValue(String value, JTable table) {
List<Integer> rowNumbers = new ArrayList<Integer>();
for(int rowCount = 0; rowCount < table.getRowCount(); rowCount++) {
for(int columnCount = 0; columnCount < table.getColumnCount(); columnCount++) {
if(table.getvalueAt(rowCount, columnCount).toString().equals(value)) {
rowNumbers.add(rowCount);
break;
}
}
}
return rowNumbers;
}