11

好的,我想从 JTable 的第一列中获取所有数据。我虽然最好的方法是将它拉到一个ArrayList,所以我做了一个。我还做了一个实例TableModel

static DefaultTableModel model = new javax.swing.table.DefaultTableModel(); 
f.data.setModel(model); //f.data is the JTable

public static final void CalculateTotal(){
    ArrayList<String> numdata = new ArrayList<String>();

  for(int count = 1; count <= model.getRowCount(); count++){
      numdata.add(model.getValueAt(count, 1).toString());

  }
  System.out.println(numdata); 
}

这给了我一个 NullPointerException (提示尖叫)。我究竟做错了什么?

4

4 回答 4

11

我不太了解这些课程,但我猜你必须从零开始数:

for (int count = 0; count < model.getRowCount(); count++){
  numdata.add(model.getValueAt(count, 0).toString());
}

在 Java 中,通常从 0 开始计数(就像在大多数类 C 语言中一样)......

于 2012-08-04T21:35:05.260 回答
2

最好是发布SSCCE以显示模型初始化及其数据填充。还包括异常的详细信息,因为问题可能有多个来源。

这是一个基于@CedricReichenbach 校正的演示:

import java.util.ArrayList;
import java.util.List;

import javax.swing.table.DefaultTableModel;

public class TestModel {
    public static void main(String s[]) {
        DefaultTableModel model = new javax.swing.table.DefaultTableModel();    

        model.addColumn("Col1");
        model.addColumn("Col2");

        model.addRow(new Object[]{"1", "v2"});
        model.addRow(new Object[]{"2", "v2"});

        List<String> numdata = new ArrayList<String>();
        for (int count = 0; count < model.getRowCount(); count++){
              numdata.add(model.getValueAt(count, 0).toString());
        }

        System.out.println(numdata); 
    }
}

结果是:

[1, 2]
于 2012-08-04T21:50:59.597 回答
1

我知道这个答案有点晚了,但它实际上是一个非常容易解决的问题。您的代码在读取条目时会出错,因为表本身没有可供代码读取的条目。填充表并再次运行您的代码。问题本可以更早解决,但从您发布的代码来看,您的表中的内容并不明显。

于 2013-10-19T10:01:33.793 回答
0
       DefaultTableModel model = (DefaultTableModel) table.getModel();

        for (int i = 0; model.getRowCount() > i; i++) {
            final String col1 = (String) model.getValueAt(i, 0);
            final String col2 = (String) model.getValueAt(i, 1);

            System.out.println("Row: " + i + " Col 0: " + col1);
            System.out.println("Row: " + i + " Col 1: " + col2);
        }
于 2020-02-03T10:33:44.167 回答