我想以不同的形式为我的jtables实现一个通用的验证类来检查qty列,因为不同表格的不同表中的qty列No是不同的。为此,我希望在C#或VB中按列名称获取列值。
我的要求如下。
int qty=jtable.getValueAt(rowNo,"columnName");
现在我正在使用
int qty=jtable.getValueAt(rowNo,colNo);
有没有办法按列名称或JTable标题找到列#?
答案 0 :(得分:8)
你应该尝试使用它:
int qty = jtable.getValueAt( rowNo, jtable.getColumn("columnName").getModelIndex() );
答案 1 :(得分:6)
您可能应该询问TableModel
,而不是JTable
,它可能会重新排列其列。一种方法是让TableModel
实现合适的接口,例如
public interface Quantifiable {
public int getQuantity(int row);
}
附录:请告诉我们如何实施此界面。
很大程度上取决于您现有的TableModel
课程之间的关系。假设 all 在某些列中有一个数字量。如果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();
}
...
}
答案 2 :(得分: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's Table Cell Editor)的一般表格单元侦听器的完整代码!
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);
答案 3 :(得分: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
,否则你可能会相应地对待它。
答案 4 :(得分:1)
嗨,这是对你的问题的简单回答:
int qty=jtable.getValueAt(rowNo,jtable.convertColumnIndexToView(jtable.getColumn("columnName").getModelIndex()));