gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-12-01 07:52:57 26 4
gpt4 key购买 nike

我对 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/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com