2

在 Java 中,是否可以在 JTable 中通过查找包含在该行中的指定值来获取该行的索引?我正在使用自定义表格模型。例如,考虑一个具有三列和三行的表:

Row 1 = A, B, C
Row 2 = D, E, F
Row 3 = G, H, I

如果我只知道表中某处有一个值“F”,我如何找出值“F”所在行的索引?

4

3 回答 3

8

如果表模型可用,一种蛮力的方法是按行和列循环并将给定值(例如,'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;
            }
        }
    }
 }
于 2013-01-07T13:40:43.793 回答
3
 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;
 }
于 2013-01-07T13:46:50.780 回答
1

以防万一如果有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;
}
于 2013-01-07T14:27:36.780 回答