问题描述
我在 JTable
中搜索排序,我参考了许多文章,但无法获得对表格进行排序的最简单方法。我也知道 TableRowSorter
可能会有所帮助,但不知道如何。作为 JTable
的新手,我在这里创建了一个新问题。
I was searching for Sorting in JTable
and I referred many articles, but couldn't get the easiest way to sort the table. I also know that TableRowSorter
could be somehow helpful but don't know how. Being new to JTable
, I am creating a new question here.
我的表结构是这样的
| People | Place | Organisation | Event | Mentions |
_____________________________________________________________
| Ramanuj | India | Tata Consultancy | Party'14 | 500000 |
| Prankster | USA | Microsoft Pvt Ltd | Party'14 | 900000 |
我想要的是排序我的桌子Descending基于第4栏(提及)。如果计数(提及)相同,则应按第1列升序排序(人物)
What I want here is to sort my table Descending based on 4th column ("Mentions"). If counts (Mentions) are same, it should sort Ascending by 1st column ("People")
CSVReader reader = new CSVReader(new FileReader(file));
List<String[]> myEntries = reader.readAll();
String[][] rowData = myEntries.toArray(new String[0][]);
String[] columnNames = { "People", "Place", "Organisation", "Event", "Mentions" };
DefaultTableModel tableModel = new DefaultTableModel(rowData, columnNames);
推荐答案
根据
JTable table = new JTable(tableModel);
TableRowSorter<TableModel> sorter = new TableRowSorter<TableModel>(table.getModel());
table.setRowSorter(sorter);
List<RowSorter.SortKey> sortKeys = new ArrayList<>(25);
sortKeys.add(new RowSorter.SortKey(4, SortOrder.ASCENDING));
sortKeys.add(new RowSorter.SortKey(0, SortOrder.ASCENDING));
sorter.setSortKeys(sortKeys);
已更新
你确定它会排序吗?
...是
import java.awt.EventQueue;
import java.util.ArrayList;
import java.util.List;
import javax.swing.JFrame;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import javax.swing.RowSorter;
import javax.swing.SortOrder;
import javax.swing.UIManager;
import javax.swing.UnsupportedLookAndFeelException;
import javax.swing.table.DefaultTableModel;
import javax.swing.table.TableModel;
import javax.swing.table.TableRowSorter;
public class Test {
public static void main(String[] args) {
new Test();
}
public Test() {
EventQueue.invokeLater(new Runnable() {
@Override
public void run() {
try {
UIManager.setLookAndFeel(UIManager.getSystemLookAndFeelClassName());
} catch (ClassNotFoundException | InstantiationException | IllegalAccessException | UnsupportedLookAndFeelException ex) {
ex.printStackTrace();
}
DefaultTableModel model = new DefaultTableModel(new String[]{"People", "Place", "Organisation", "Event", "Mentions"}, 0);
model.addRow(new Object[]{"Prankster", "USA", "Microsoft Pvt Ltd", "Party'14", 900000});
model.addRow(new Object[]{"Ramanuj", "India", "Tata Consultancy", "Party'14", 500000});
model.addRow(new Object[]{"Banana", "India", "Tata Consultancy", "Party'14", 500000});
JTable table = new JTable(model);
TableRowSorter<TableModel> sorter = new TableRowSorter<TableModel>(table.getModel());
table.setRowSorter(sorter);
List<RowSorter.SortKey> sortKeys = new ArrayList<>(25);
sortKeys.add(new RowSorter.SortKey(4, SortOrder.ASCENDING));
sortKeys.add(new RowSorter.SortKey(0, SortOrder.ASCENDING));
sorter.setSortKeys(sortKeys);
JFrame frame = new JFrame("Testing");
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
frame.add(new JScrollPane(table));
frame.pack();
frame.setLocationRelativeTo(null);
frame.setVisible(true);
}
});
}
}
已更新
您可以直接从视图中提取数据...
You can extract the data from the view directly...
for (int row = 0; row < table.getRowCount(); row++) {
String people = table.getValueAt(row, 0).toString();
String place = table.getValueAt(row, 1).toString();
String organisation = table.getValueAt(row, 2).toString();
String event = table.getValueAt(row, 3).toString();
int mentions = (int)table.getValueAt(row, 4);
//...
}
这将为您提供数据查看(或排序)订单......
This will give you the data in the "view" (or sorted) order...
这篇关于如何以最短的方式对JTable进行排序?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!