JTable的RowSorter没有正确sorting整数(1,10,100 … 2,20 … 3)

我对Java相当陌生,而且我一整天都试图过度地解决这个问题,但是它不能工作。 我试图编写一个Java应用程序连接到一个Excel工作表,并允许通过GUI插入/保存/sorting适合电影数据库的数据。 这是来自类的代码,其中的GUI魔术和sorting发生:

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 List<Film> rowlist = new ArrayList<Film>(); static String[] rowData = {}; JTable table = new JTable(); Excelverbindung excelverb = new Excelverbindung(); public Tabelle() { } private List<Film> getRowData() { Excelverbindung excelverb = new Excelverbindung(); rowlist = excelverb.leseExcel(); return rowlist; } public JTable fuellenTabelle() { TableModel tableModel = new DefaultTableModel(columnNames, 0); TableRowSorter<TableModel> sorter = new TableRowSorter<TableModel>(); 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不能sortingstring值(nummer也是一个string),我得到。 但即使将string转换为整数(我今天把我的进度调整到了代码的最后一个“可运行”状态,因此string数组也不能解决这个问题)。 我遇到了整个getClass,并将它们设置为Integer.Class等等,但无法精确地使用它。 无论哪种方式,它所做的只是允许基于string的sorting而不是单元格内容的数值。

任何帮助将不胜感激,我读的相关主题要么是我很难遵守,要么没有涵盖我的具体问题。

所以,请耐心等待,因为英语既不是我的母语,也不是我擅长Java的。

感谢一堆和最好的问候。

您需要告诉表中每列中存储了什么types的数据,因此可以使用适当的比较器进行sorting。

通过重写TableModel的getColumnClass()方法(或JTable,如果在创build时无法访问TableModel),可以这样做。 就像是:

 @Override public Class getColumnClass(int column) { if (column == 3) return Integer.class; else return String.class; } 

此外,请确保您将Integer objects in the存储Integer objects in the TableModel中,而不仅仅是Integer的String表示forms。

你需要为这样的分拣机对象设置比较

  sorter.setComparator(0, new Comparator<Integer>() { @Override public int compare(Integer o1, Integer o2) { int len1 = o1.toString().length(); int len2 = o2.toString().length(); if (len1==len2) { return o1.compareTo(o2); } else { return len1-len2; } } });