6

我想为我的 jtables 以不同的形式实现一个通用的验证类来检查 qty 列,因为不同形式的不同表中的 qty 列 No 是不同的。为此,我想在 C# 或 VB 中类似地按列名称获取列值。

我的要求如下。

 int qty=jtable.getValueAt(rowNo,"columnName");

现在我正在使用

 int qty=jtable.getValueAt(rowNo,colNo);

有什么方法可以按列名或 JTable 的标题查找列#?

4

5 回答 5

11

你应该尝试使用这个:

int qty = jtable.getValueAt( rowNo, jtable.getColumn("columnName").getModelIndex() );
于 2013-12-04T19:14:22.587 回答
6

您可能应该问的是TableModel,而不是JTable,它的列可能会重新排列。一种方法是让您TableModel实现一个合适的接口,例如,

public interface Quantifiable {
    public int getQuantity(int row);
}

附录:请告诉如何实现这个接口

很大程度上取决于现有TableModel类之间的关系。假设所有列中都有一个数字量。如果quantityCol模型索引是具有 type 的列,则Number可以执行以下操作:

public class QuantifiableTableModel
        extends AbstractTableModel implements Quantifiable {

    private int quantityCol;

    public QuantifiableTableModel(int quantityCol) {
        this.quantityCol = quantityCol;
    }

    @Override
    public int getQuantity(int row) {
        Number n = (Number) getValueAt(row, quantityCol);
        return n.intValue();
    }
    ...
}
于 2012-11-20T03:51:04.753 回答
2

嗨,这是对您的问题的简单回答:

int qty=jtable.getValueAt(rowNo,jtable.convertColumnIndexToView(jtable.getColumn("columnName").getModelIndex()));
于 2017-09-23T12:39:05.570 回答
1

我在代码中使用三元运算符完成了我的任务

 int colNo = ((tbl.getModel().getColumnName(tcl.getColumn()).equalsIgnoreCase("Qty"))
||  (tbl.getModel().getColumnName(tcl.getColumn()).equalsIgnoreCase("Weight"))
|| (tbl.getModel().getColumnName(tcl.getColumn()).equalsIgnoreCase("Wt"))
 ? tcl.getColumn() : -1);

我使用Bob Camick 的表格单元格编辑器的通用表格单元格侦听器的完整代码) !

final JTable table = (JTable) jComp.get(a);
tbl.getTableHeader().setReorderingAllowed(false); 

 Action actionProd = new AbstractAction() {

    public void actionPerformed(ActionEvent e) {

        Utility util = new Utility("GoldNew");

        TableCellListener tcl = (TableCellListener) e.getSource();
        System.out.println("Row   : " + tcl.getRow());
        System.out.println("Column: " + tcl.getColumn());
        System.out.println("Old   : " + tcl.getOldValue());
        System.out.println("New   : " + tcl.getNewValue());
        int colNo = ((table.getModel().getColumnName(tcl.getColumn()).equalsIgnoreCase("Qty"))
                || (table.getModel().getColumnName(tcl.getColumn()).equalsIgnoreCase("Weight"))
                || (table.getModel().getColumnName(tcl.getColumn()).equalsIgnoreCase("Wt"))
                ? tcl.getColumn() : -1);

        if (tcl.getColumn() == colNo) {
            int wt = 0;
            Object qtyO = tcl.getNewValue();
            try {
                qtyO = tcl.getNewValue();
                if (qtyO != null) {
                    wt = Integer.parseInt(qtyO.toString());
                }

                if (wt < 0) {
                    table.getModel().setValueAt(tcl.getOldValue(), tcl.getRow(), colNo);
                }

            } catch (Exception ex) {
                util.ShowMessage("Please enter the Numbers only", "Error!");
                table.getModel().setValueAt(tcl.getOldValue(), tcl.getRow(), colNo);
                ex.printStackTrace();
            }




        }

    }
};
TableCellListener tclProd = new TableCellListener(table, actionProd);       
于 2012-11-20T08:21:01.250 回答
1

我面临着同样的问题。这是我的实现:

int nameColNo = getColumnIndex(table, "Name");
String name = (String)table.getValueAt(rowNo, nameColNo);

private int getColumnIndex (JTable table, String header) {
    for (int i=0; i < table.getColumnCount(); i++) {
        if (table.getColumnName(i).equals(header)) return i;
    }
    return -1;
}

当然,如果是您创建了预期永远不会返回的表头-1,否则您可能会相应地对待它。

于 2015-11-12T18:48:46.623 回答