按列名或标题查找列 # - JTable



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

我的要求如下。

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

现在我正在使用

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

有没有办法按列名称或 JTable 的标题查找列 #?

你应该尝试使用它:

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

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

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

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

很大程度上取决于现有TableModel类之间的关系。假设所有列都有一个数字数量。如果模型索引quantityCol是具有 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();
    }
    ...
}

我遇到了同样的问题。这是我的实现:

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,否则你可能会相应地对待它。

嗨,

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

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

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

 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);

我的一般表格单元格侦听器的完整代码使用鲍勃·卡米克的表格单元格编辑器)!

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);       

最新更新