java - JTable 的 RowSorter 未正确排序整数 (1,10,100...2,20...3)

标签 java excel swing sorting jtable

我对 Java 还很陌生,我一整天都过度尝试自己解决这个问题,但它不起作用。我正在尝试编写一个与 Excel 工作表连接的 Java 应用程序,并允许通过 GUI 插入/保存/排序适合电影数据库的数据。下面是类中的代码,其中发生了 GUI 魔法和排序:

    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 似乎无法对我得到的字符串值(nummer 也是字符串)进行排序。但即使将字符串转换为整数(我今天将进度反转到代码的最后一个“可运行”状态,因此是字符串数组)也无法解决问题。我遇到了整个 getClass 并将它们设置为 Integer.Class 等等,但无法理解如何准确使用它。无论哪种方式,它所做的只是允许基于字符串而不是单元格内容的数值进行排序。

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

所以,请耐心等待,因为英语不是我的母语,而且我的 Java 也不是很熟练。

非常感谢并致以最诚挚的问候。

最佳答案

您需要告诉表每列中存储的数据类型,以便可以使用正确的比较器进行排序。

您可以通过重写 TableModel 的 getColumnClass() 方法(或者 JTable,如果您在创建 TableModel 时无权访问该方法)来实现此目的。像这样的东西:

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

此外,请确保在 TableModel 中存储 Integer 对象,而不仅仅是整数的字符串表示形式。

关于java - JTable 的 RowSorter 未正确排序整数 (1,10,100...2,20...3),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34026013/

相关文章:

JAVA 复制对象的新实例

java - 如何在android中从出生日期计算一个人的确切年龄

java - 错误 : Byte "239" is not a member of the (7-bit) ASCII character set

java - Angular2 - 下载从 RestService 收到的 XLS

vba - 如果在 Excel 中重复,则删除所有行 - VBA

java - jpanel 上的 Keylistener 不起作用

java - 如何使错误页面 (http 500) 在 IceFaces 中工作?

java - 如何预订不同时区的在线 session (视频通话)?

regex - 替换工作表名称中的多个无效字符

java - Substance UI 和自定义 JComponent 的 TitledBorder 问题