当前位置:  开发笔记 > 编程语言 > 正文

JTable的RowSorter没有正确排序整数(1,10,100 ... 2,20 ... 3)

如何解决《JTable的RowSorter没有正确排序整数(1,10,1002,203)》经验,为你挑选了1个好方法。

我对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 List rowlist = 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语言.

谢谢一堆和最好的问候.



1> camickr..:

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

您可以通过覆盖getColumnClass()TableModel 的方法(如果在创建TableModel时无法访问Tableable)来执行此操作.就像是:

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

此外,请确保存储Integer objects in theTableModel`,而不仅仅是Integer的String表示形式.

推荐阅读
手机用户2402851335
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有