2017-08-31 59 views
0

我设计的JTable这样的:JTable的头突然改变其列名

enter image description here

当我编译我的Java GUI Netbeans的程序,它有没有问题:

enter image description here

但是当我按了一个JButton,我用这个代码上传了excel:

private void b_browseActionPerformed(java.awt.event.ActionEvent evt) {           
    // TODO add your handling code here: 
    int column, row; 
    JFileChooser chooser = new JFileChooser(); 
    chooser.showOpenDialog(this); 
    File file = chooser.getSelectedFile(); 
    chooser.setFileFilter(new FileNameExtensionFilter("Excel File", "xls")); 
    String al = file.getAbsolutePath(); 
    File excelFile = new File(al); 
    if(!file.getName().endsWith("xls")){ 
JOptionPane.showMessageDialog(null, 
    "Pilih file Excel (.xls) saja!", 
    "Error",JOptionPane.ERROR_MESSAGE); 
} 
else 
{ 
if (excelFile.exists()) { 
    try { 
     Workbook workbook = Workbook.getWorkbook(excelFile); 
     Sheet sheet = workbook.getSheets()[0]; 
     TableModel model = new DefaultTableModel(sheet.getRows(), sheet.getColumns()); 
     DefaultTableModel model2 = new DefaultTableModel(null, JdlTabel); 
     for (row = 0; row < sheet.getRows(); row++) { 
      for (column = 0; column < sheet.getColumns(); column++) { 
       String content = sheet.getCell(column, row).getContents(); 
       model.setValueAt(content, row, column); 
       data[row][column]=Double.parseDouble(content); 
       n_data = sheet.getRows(); 
       k_data = sheet.getColumns(); 

      } 
     } 
     j_latih.setModel(model2); 
     j_latih.setModel(model); //input data to Jtable 
    } catch (Exception e) { 
     JOptionPane.showMessageDialog(null, "Error : " + e); 
     e.printStackTrace(); 
    } 

} else { 
    JOptionPane.showMessageDialog(null, "There is no data!"); } 
} 
    cek_kmeans=0; 
    cek_data=1;//control tombol  
}           

突然表格列名称变更如下:

enter image description here

那么,什么是错的?我该如何解决?

回答

1

JTable的头突然改变其列名

DefaultTableModel model2 = new DefaultTableModel(null, JdlTabel); 

在重新创建表格模型,您指定的列标题“空”。所以使用默认标题。

的解决方法是:当你重新创建模型

  1. 使用原始列名。
  2. 不要重新创建整个模型。相反,您可以使用DefaultTableModel. Then you use the addRow(...)method of the DefaultTableModel`的setRowCount(0)删除当前模型中的所有行,以一次将数据加载回模型一行。
+0

但问题是,当我上传要显示的Excel文件时,jtable列的名称发生了变化。 –

+0

@YohanesSetiawan,该表获取TableModel的列名称。每当你设置一个新模型时,你都会得到新的列名。当你使用“null”作为列名时,你希望发生什么? – camickr