我对Java很陌生,我一整天都试图过度解决这个问题,但它无法正常工作.我正在尝试编写一个连接Excel工作表的Java应用程序,并允许通过GUI插入/保存/排序适合电影数据库的数据.这是来自classe的代码,其中GUI-magic和排序发生:
package gui; import java.util.ArrayList; import java.util.List; import javax.swing.JOptionPane; import javax.swing.JTable; import javax.swing.UIManager; import javax.swing.table.DefaultTableModel; import javax.swing.table.TableModel; import javax.swing.table.TableRowSorter; import object.Film; import excel.Excelverbindung; public class Tabelle extends JTable { /** * */ private static final long serialVersionUID = 1L; static String[] columnNames = { "Nr.", "Titel", "Jahr", "Regie", "Primäres Genre", "Sekundäres Genre", "Wertung", "Originaltitel" }; static Listrowlist = new ArrayList (); static String[] rowData = {}; JTable table = new JTable(); Excelverbindung excelverb = new Excelverbindung(); public Tabelle() { } private List getRowData() { Excelverbindung excelverb = new Excelverbindung(); rowlist = excelverb.leseExcel(); return rowlist; } public JTable fuellenTabelle() { TableModel tableModel = new DefaultTableModel(columnNames, 0); TableRowSorter sorter = new TableRowSorter (); table.setRowSorter(sorter); sorter.setModel(tableModel); table.setModel(tableModel); Tabelle.rowlist = getRowData(); String[] film = new String[7]; for (Film temp : rowlist) { film[0] = temp.getNummer(); film[1] = temp.getName(); film[2] = temp.getJahr(); film[3] = temp.getRegie(); film[4] = temp.getGenre1(); film[5] = temp.getGenre2(); film[6] = temp.getWertung(); ((DefaultTableModel) tableModel).addRow(film); } System.out.println("Tabelle erzeugt"); return table; } public void getRandomFilm() { Film film; excelverb.oeffneVerbindung(); film = excelverb.holeZufaelligerFilm(); excelverb.schließeVerbindung(); film.getNummer(); film.getName(); film.getJahr(); film.getRegie(); film.getGenre1(); film.getGenre2(); film.getWertung(); UIManager.put("OptionPane.cancelButtonText", "Ach, egal..."); UIManager.put("OptionPane.okButtonText", "Nächster!"); int input = JOptionPane.showOptionDialog( null, "Nr.:" + film.getNummer() + " Titel: " + film.getName() + " Jahr: " + film.getJahr() + " Genres: " + film.getGenre1() + " und " + film.getGenre2() + " von " + film.getRegie(), "Schau einfach den Film...", JOptionPane.OK_CANCEL_OPTION, JOptionPane.INFORMATION_MESSAGE, null, null, null); if (input == JOptionPane.OK_OPTION) { getRandomFilm(); } else if (input == JOptionPane.CANCEL_OPTION) { } } }
似乎RowSorter无法对String值进行排序(nummer也是一个String),我得到了.但即使将字符串转换为整数(我将今天的进度转换为代码的最后一个"可运行"状态,因此字符串数组)也无法解决它.我遇到了整个getClass并将它们设置为Integer.Class等等,但无法完全理解如何使用它.无论哪种方式,它所做的只是允许基于String的排序 - 而不是单元格内容的nummeric值.
任何帮助将不胜感激,我读到的相关主题要么我很难遵循,要么没有涵盖我的具体问题.
所以,请耐心等待,因为英语既不是我的母语,也不是我熟练的Java语言.
谢谢一堆和最好的问候.
您需要告诉表格每列中存储的数据类型,以便可以使用正确的Comparator进行排序.
您可以通过覆盖getColumnClass()
TableModel 的方法(如果在创建TableModel时无法访问Tableable)来执行此操作.就像是:
@Override public Class getColumnClass(int column) { if (column == 3) return Integer.class; else return String.class; }
此外,请确保存储Integer objects in the
TableModel`,而不仅仅是Integer的String表示形式.