JTable 摆动异常
JTable swing exception
这是对我一天前提出的一个问题的跟进,我一直在尝试调试代码但没有成功,但基本上应用程序应该允许用户 select CSV他们想要导入或查看,在 selecting 文件之后,他们将只能查看 JTable 中 Csv 的内容。目前我可以查看 csv 中的数据,但它没有按预期显示在 Jtable 中。这是下面程序的代码,除了 netbeans 向我抛出的异常。
public class Asist_payment_import_v1 extends JPanel implements ActionListener{
private final JTable Table;
public Asist_payment_import_v1(){
super(new BorderLayout(3,3));
this.Table = new JTable(new MiModel());
this.Table.setPreferredScrollableViewportSize(new Dimension(700,70));
this.Table.setFillsViewportHeight(true);
JPanel ButtonOpen = new JPanel(new FlowLayout(FlowLayout.CENTER));
//the below utton will be used to upload csv data to Database, the action listener should connect to the db, and pass data into the Db.
//JPanel ButtonUpload = new JPanel(new FlowLayout(FlowLayout.LEFT));
JButton open_file = new JButton("Open");
JButton save_file = new JButton("Save");
ButtonOpen.add(open_file);
add(ButtonOpen, BorderLayout.SOUTH);
open_file.addActionListener(this);
save_file.addActionListener(this);
//create scrollPane to this Panel
JScrollPane scrollpane = new JScrollPane(Table);
//add the scroll pane to this pane
add(scrollpane,BorderLayout.CENTER);
//add Border
setBorder(new EmptyBorder(5,5,5,5));
}
public void actionPerformed(ActionEvent Event)
{
JFileChooser file_chooser = new JFileChooser();
boolean pressed = true;
if(pressed)
{
int ReturnVal = file_chooser.showOpenDialog(null);
CSVFile Rd = new CSVFile();
MiModel NewModel = new MiModel();
this.Table.setModel(NewModel);// to set the Table model
File DataFile = file_chooser.getSelectedFile();
ArrayList<String[]> rs2 = Rd.ReadCSVFile(DataFile);
NewModel.AddCSVData(rs2);
System.out.println("Rows: " +NewModel.getRowCount());
System.out.println("Cols: " +NewModel.getColumnCount());
}
}
public class CSVFile
{
private ArrayList<String[]> Rs = new ArrayList<>();
private String[] OneRow;
public ArrayList<String[]> ReadCSVFile(File DataFile){
try{
BufferedReader brd = new BufferedReader (new FileReader(DataFile));
while(brd.readLine()!= null){
String st = brd.readLine();
OneRow = st.split(",");
Rs.add(OneRow);
System.out.println(Arrays.toString(OneRow));
}
}//end try
catch(Exception ex){
String errmsg = ex.getMessage();
System.out.println("File not Found: "+errmsg);
}//end exception handling
return Rs;
}//End of ArrayList_readCSVFile class
}//End of CSVFile class
private static void createAndShowGui()
{
//setup Window
JFrame frame = new JFrame("PaymentImport");
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
//setup the conentPane
Asist_payment_import_v1 newContentPane = new Asist_payment_import_v1();
frame.setContentPane(newContentPane);
//display the window
frame.pack();
frame.setVisible(true);
}
class MiModel extends AbstractTableModel
{
private String [] columnNames = {"Nr","LinkId","Ammount","PayDate","Month","Year","Printed","User","RefNo","ShortSwi",
"BranchNo","SyncHQ","SyncBranch","SysDateStamp","RDReason","UnderPrice","PaydMark","RecieptPrinted"};
private ArrayList<String[]>Data = new ArrayList<>();
public void AddCSVData(ArrayList<String[]> DataIn){
this.Data = DataIn;
this.fireTableDataChanged();
}
@Override
public int getColumnCount(){
return columnNames.length;
}
@Override
public int getRowCount(){
return Data.size();
}
@Override
public String getColumnName(int col){
return columnNames[col];
}
@Override
public Object getValueAt(int row, int col){
return Data.get(row)[col];
}
}
/**
* @param args the command line arguments
*/
public static void main(String[] args) {
// schedule a job for the event-despatching thread:
//creating and showing this application's GUI
javax.swing.SwingUtilities.invokeLater(new Runnable(){
public void run(){
createAndShowGui();
}
}); } }
抛出的异常:
Exception in thread "AWT-EventQueue-0" java.lang.ArrayIndexOutOfBoundsException: 16
at asist_payment_import_v1.Asist_payment_import_v1$MiModel.getValueAt(Asist_payment_import_v1.java:150)
at javax.swing.JTable.getValueAt(JTable.java:2717)
at javax.swing.JTable.prepareRenderer(JTable.java:5706)
at javax.swing.plaf.basic.BasicTableUI.paintCell(BasicTableUI.java:2114)
at javax.swing.plaf.basic.BasicTableUI.paintCells(BasicTableUI.java:2016)
at javax.swing.plaf.basic.BasicTableUI.paint(BasicTableUI.java:1812)
at javax.swing.plaf.ComponentUI.update(ComponentUI.java:161)
at javax.swing.JComponent.paintComponent(JComponent.java:780)
at javax.swing.JComponent.paint(JComponent.java:1056)
at javax.swing.JComponent.paintToOffscreen(JComponent.java:5210)
at javax.swing.RepaintManager$PaintManager.paintDoubleBuffered(RepaintManager.java:1579)
at javax.swing.RepaintManager$PaintManager.paint(RepaintManager.java:1502)
at javax.swing.RepaintManager.paint(RepaintManager.java:1272)
at javax.swing.JComponent._paintImmediately(JComponent.java:5158)
at javax.swing.JComponent.paintImmediately(JComponent.java:4969)
at javax.swing.RepaintManager.run(RepaintManager.java:831)
at javax.swing.RepaintManager.run(RepaintManager.java:814)
at java.security.AccessController.doPrivileged(Native Method)
at java.security.ProtectionDomain$JavaSecurityAccessImpl.doIntersectionPrivilege(ProtectionDomain.java:80)
at javax.swing.RepaintManager.paintDirtyRegions(RepaintManager.java:814)
at javax.swing.RepaintManager.paintDirtyRegions(RepaintManager.java:789)
at javax.swing.RepaintManager.prePaintDirtyRegions(RepaintManager.java:738)
at javax.swing.RepaintManager.access00(RepaintManager.java:64)
at javax.swing.RepaintManager$ProcessingRunnable.run(RepaintManager.java:1732)
at java.awt.event.InvocationEvent.dispatch(InvocationEvent.java:311)
at java.awt.EventQueue.dispatchEventImpl(EventQueue.java:756)
at java.awt.EventQueue.access0(EventQueue.java:97)
at java.awt.EventQueue.run(EventQueue.java:709)
at java.awt.EventQueue.run(EventQueue.java:703)
at java.security.AccessController.doPrivileged(Native Method)
at java.security.ProtectionDomain$JavaSecurityAccessImpl.doIntersectionPrivilege(ProtectionDomain.java:80)
at java.awt.EventQueue.dispatchEvent(EventQueue.java:726)
at java.awt.EventDispatchThread.pumpOneEventForFilters(EventDispatchThread.java:201)
at java.awt.EventDispatchThread.pumpEventsForFilter(EventDispatchThread.java:116)
at java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:105)
at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:101)
at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:93)
at java.awt.EventDispatchThread.run(EventDispatchThread.java:82)
这是在 netbeans 输出面板上显示的部分结果,而不是 JTable:
[2019017, 288633, 69.00, 20171127, 11, 2017, "False", "Annamarie", "Group
Payment (19061)", "False", "All", 0, , , "2017-11-27 09:43:13", "", 54.00,
20171127]
[2019019, 288638, 42.00, 20171127, 11, 2017, "False", "Annamarie", "Group
Payment (19061)", "False", "All", 0, , , "2017-11-27 09:43:13", "", 27.00,
20171127]
[2019021, 315068, 42.00, 20171127, 11, 2017, "False", "Annamarie", "Group
Payment (19061)", "False", "All", 0, , , "2017-11-27 09:43:14", "", 27.00,
20171127]
[2019023, 294133, 69.00, 20171127, 11, 2017, "False", "Annamarie", "Group
Payment (19061)", "False", "All", 0, , , "2017-11-27 09:43:14", "", 54.00,
20171127]
[2019025, 288623, 130.00, 20171127, 11, 2017, "False", "Annamarie", "Group
Payment (19063)", "False", "All", 0, , , "2017-11-27 09:43:30", "", 1068.80,
20171127]
[2019027, 288625, 105.00, 20171127, 11, 2017, "False", "Annamarie", "Group
Payment (19063)", "False", "All", 0, , , "2017-11-27 09:43:31", "", 855.00,
20171127]
Rows: 690551
Cols: 18
我找到了这个问题的解决方案,我对读取 csv 数据的 CSV 方法进行了更改。这是所做的更改
public class CSVFile
{
private ArrayList<String[]> arrLs = new ArrayList<>();
private Object OneRow;
public ArrayList<String[]> ReadCSVFile(File DataFile)
{
try
{
//BufferedReader to Read through CSV Contents
BufferedReader reader = new BufferedReader (new FileReader(DataFile));
String line;
// while loop to read through the data, while bufferedreader is not null-do ....
while(reader.readLine()!= null)
{
try
{
line = reader.readLine();
if(line != null)
{
String[] array = line.split(",");
for(String result:array)
{
//System.out.println(OneRow[2]+");
System.out.println(result);
}
}
}
catch(Exception ex)
{
ex.printStackTrace();
}
finally
{
if(reader == null)
{
reader.close();
}
}
//if statement needed in the case the
//Selected CSV has more than the required number of ColumnHeaders
//and the BufferedReader needs to skip the first Row, as this is the
//columnHeaders and they cannot be included again
String read = reader.readLine();//bufferedreader string variable
OneRow = read.split(",");
arrLs.add((String[]) OneRow);
// System.out.println(Arrays.toString(OneRow));
}//end try
catch(Exception ex)
{
String errmsg = ex.getMessage();
//System.out.println("File not Found: "+errmsg);
} // end exception handling
return (ArrayList<String[]>) arrLs;
} //End of ArrayList_readCSVFile class
} //End of CSVFile class
}
这让我可以查看 JTable 中的 csv 数据,这是这里的主要问题
这是对我一天前提出的一个问题的跟进,我一直在尝试调试代码但没有成功,但基本上应用程序应该允许用户 select CSV他们想要导入或查看,在 selecting 文件之后,他们将只能查看 JTable 中 Csv 的内容。目前我可以查看 csv 中的数据,但它没有按预期显示在 Jtable 中。这是下面程序的代码,除了 netbeans 向我抛出的异常。
public class Asist_payment_import_v1 extends JPanel implements ActionListener{
private final JTable Table;
public Asist_payment_import_v1(){
super(new BorderLayout(3,3));
this.Table = new JTable(new MiModel());
this.Table.setPreferredScrollableViewportSize(new Dimension(700,70));
this.Table.setFillsViewportHeight(true);
JPanel ButtonOpen = new JPanel(new FlowLayout(FlowLayout.CENTER));
//the below utton will be used to upload csv data to Database, the action listener should connect to the db, and pass data into the Db.
//JPanel ButtonUpload = new JPanel(new FlowLayout(FlowLayout.LEFT));
JButton open_file = new JButton("Open");
JButton save_file = new JButton("Save");
ButtonOpen.add(open_file);
add(ButtonOpen, BorderLayout.SOUTH);
open_file.addActionListener(this);
save_file.addActionListener(this);
//create scrollPane to this Panel
JScrollPane scrollpane = new JScrollPane(Table);
//add the scroll pane to this pane
add(scrollpane,BorderLayout.CENTER);
//add Border
setBorder(new EmptyBorder(5,5,5,5));
}
public void actionPerformed(ActionEvent Event)
{
JFileChooser file_chooser = new JFileChooser();
boolean pressed = true;
if(pressed)
{
int ReturnVal = file_chooser.showOpenDialog(null);
CSVFile Rd = new CSVFile();
MiModel NewModel = new MiModel();
this.Table.setModel(NewModel);// to set the Table model
File DataFile = file_chooser.getSelectedFile();
ArrayList<String[]> rs2 = Rd.ReadCSVFile(DataFile);
NewModel.AddCSVData(rs2);
System.out.println("Rows: " +NewModel.getRowCount());
System.out.println("Cols: " +NewModel.getColumnCount());
}
}
public class CSVFile
{
private ArrayList<String[]> Rs = new ArrayList<>();
private String[] OneRow;
public ArrayList<String[]> ReadCSVFile(File DataFile){
try{
BufferedReader brd = new BufferedReader (new FileReader(DataFile));
while(brd.readLine()!= null){
String st = brd.readLine();
OneRow = st.split(",");
Rs.add(OneRow);
System.out.println(Arrays.toString(OneRow));
}
}//end try
catch(Exception ex){
String errmsg = ex.getMessage();
System.out.println("File not Found: "+errmsg);
}//end exception handling
return Rs;
}//End of ArrayList_readCSVFile class
}//End of CSVFile class
private static void createAndShowGui()
{
//setup Window
JFrame frame = new JFrame("PaymentImport");
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
//setup the conentPane
Asist_payment_import_v1 newContentPane = new Asist_payment_import_v1();
frame.setContentPane(newContentPane);
//display the window
frame.pack();
frame.setVisible(true);
}
class MiModel extends AbstractTableModel
{
private String [] columnNames = {"Nr","LinkId","Ammount","PayDate","Month","Year","Printed","User","RefNo","ShortSwi",
"BranchNo","SyncHQ","SyncBranch","SysDateStamp","RDReason","UnderPrice","PaydMark","RecieptPrinted"};
private ArrayList<String[]>Data = new ArrayList<>();
public void AddCSVData(ArrayList<String[]> DataIn){
this.Data = DataIn;
this.fireTableDataChanged();
}
@Override
public int getColumnCount(){
return columnNames.length;
}
@Override
public int getRowCount(){
return Data.size();
}
@Override
public String getColumnName(int col){
return columnNames[col];
}
@Override
public Object getValueAt(int row, int col){
return Data.get(row)[col];
}
}
/**
* @param args the command line arguments
*/
public static void main(String[] args) {
// schedule a job for the event-despatching thread:
//creating and showing this application's GUI
javax.swing.SwingUtilities.invokeLater(new Runnable(){
public void run(){
createAndShowGui();
}
}); } }
抛出的异常:
Exception in thread "AWT-EventQueue-0" java.lang.ArrayIndexOutOfBoundsException: 16
at asist_payment_import_v1.Asist_payment_import_v1$MiModel.getValueAt(Asist_payment_import_v1.java:150)
at javax.swing.JTable.getValueAt(JTable.java:2717)
at javax.swing.JTable.prepareRenderer(JTable.java:5706)
at javax.swing.plaf.basic.BasicTableUI.paintCell(BasicTableUI.java:2114)
at javax.swing.plaf.basic.BasicTableUI.paintCells(BasicTableUI.java:2016)
at javax.swing.plaf.basic.BasicTableUI.paint(BasicTableUI.java:1812)
at javax.swing.plaf.ComponentUI.update(ComponentUI.java:161)
at javax.swing.JComponent.paintComponent(JComponent.java:780)
at javax.swing.JComponent.paint(JComponent.java:1056)
at javax.swing.JComponent.paintToOffscreen(JComponent.java:5210)
at javax.swing.RepaintManager$PaintManager.paintDoubleBuffered(RepaintManager.java:1579)
at javax.swing.RepaintManager$PaintManager.paint(RepaintManager.java:1502)
at javax.swing.RepaintManager.paint(RepaintManager.java:1272)
at javax.swing.JComponent._paintImmediately(JComponent.java:5158)
at javax.swing.JComponent.paintImmediately(JComponent.java:4969)
at javax.swing.RepaintManager.run(RepaintManager.java:831)
at javax.swing.RepaintManager.run(RepaintManager.java:814)
at java.security.AccessController.doPrivileged(Native Method)
at java.security.ProtectionDomain$JavaSecurityAccessImpl.doIntersectionPrivilege(ProtectionDomain.java:80)
at javax.swing.RepaintManager.paintDirtyRegions(RepaintManager.java:814)
at javax.swing.RepaintManager.paintDirtyRegions(RepaintManager.java:789)
at javax.swing.RepaintManager.prePaintDirtyRegions(RepaintManager.java:738)
at javax.swing.RepaintManager.access00(RepaintManager.java:64)
at javax.swing.RepaintManager$ProcessingRunnable.run(RepaintManager.java:1732)
at java.awt.event.InvocationEvent.dispatch(InvocationEvent.java:311)
at java.awt.EventQueue.dispatchEventImpl(EventQueue.java:756)
at java.awt.EventQueue.access0(EventQueue.java:97)
at java.awt.EventQueue.run(EventQueue.java:709)
at java.awt.EventQueue.run(EventQueue.java:703)
at java.security.AccessController.doPrivileged(Native Method)
at java.security.ProtectionDomain$JavaSecurityAccessImpl.doIntersectionPrivilege(ProtectionDomain.java:80)
at java.awt.EventQueue.dispatchEvent(EventQueue.java:726)
at java.awt.EventDispatchThread.pumpOneEventForFilters(EventDispatchThread.java:201)
at java.awt.EventDispatchThread.pumpEventsForFilter(EventDispatchThread.java:116)
at java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:105)
at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:101)
at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:93)
at java.awt.EventDispatchThread.run(EventDispatchThread.java:82)
这是在 netbeans 输出面板上显示的部分结果,而不是 JTable:
[2019017, 288633, 69.00, 20171127, 11, 2017, "False", "Annamarie", "Group
Payment (19061)", "False", "All", 0, , , "2017-11-27 09:43:13", "", 54.00,
20171127]
[2019019, 288638, 42.00, 20171127, 11, 2017, "False", "Annamarie", "Group
Payment (19061)", "False", "All", 0, , , "2017-11-27 09:43:13", "", 27.00,
20171127]
[2019021, 315068, 42.00, 20171127, 11, 2017, "False", "Annamarie", "Group
Payment (19061)", "False", "All", 0, , , "2017-11-27 09:43:14", "", 27.00,
20171127]
[2019023, 294133, 69.00, 20171127, 11, 2017, "False", "Annamarie", "Group
Payment (19061)", "False", "All", 0, , , "2017-11-27 09:43:14", "", 54.00,
20171127]
[2019025, 288623, 130.00, 20171127, 11, 2017, "False", "Annamarie", "Group
Payment (19063)", "False", "All", 0, , , "2017-11-27 09:43:30", "", 1068.80,
20171127]
[2019027, 288625, 105.00, 20171127, 11, 2017, "False", "Annamarie", "Group
Payment (19063)", "False", "All", 0, , , "2017-11-27 09:43:31", "", 855.00,
20171127]
Rows: 690551
Cols: 18
我找到了这个问题的解决方案,我对读取 csv 数据的 CSV 方法进行了更改。这是所做的更改
public class CSVFile
{
private ArrayList<String[]> arrLs = new ArrayList<>();
private Object OneRow;
public ArrayList<String[]> ReadCSVFile(File DataFile)
{
try
{
//BufferedReader to Read through CSV Contents
BufferedReader reader = new BufferedReader (new FileReader(DataFile));
String line;
// while loop to read through the data, while bufferedreader is not null-do ....
while(reader.readLine()!= null)
{
try
{
line = reader.readLine();
if(line != null)
{
String[] array = line.split(",");
for(String result:array)
{
//System.out.println(OneRow[2]+");
System.out.println(result);
}
}
}
catch(Exception ex)
{
ex.printStackTrace();
}
finally
{
if(reader == null)
{
reader.close();
}
}
//if statement needed in the case the
//Selected CSV has more than the required number of ColumnHeaders
//and the BufferedReader needs to skip the first Row, as this is the
//columnHeaders and they cannot be included again
String read = reader.readLine();//bufferedreader string variable
OneRow = read.split(",");
arrLs.add((String[]) OneRow);
// System.out.println(Arrays.toString(OneRow));
}//end try
catch(Exception ex)
{
String errmsg = ex.getMessage();
//System.out.println("File not Found: "+errmsg);
} // end exception handling
return (ArrayList<String[]>) arrLs;
} //End of ArrayList_readCSVFile class
} //End of CSVFile class
}
这让我可以查看 JTable 中的 csv 数据,这是这里的主要问题