How to sort JTable in shortest way?

前端 未结 2 981
一个人的身影
一个人的身影 2020-11-29 11:52

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

相关标签:
2条回答
  • 2020-11-29 12:48

    As per How to Use Tables: Sorting and Filtering

    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);
    

    Updated

    Are you sure it will sort?

    ...Yes

    Table

    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);
                }
            });
        }
    
    }
    

    Updated

    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...

    0 讨论(0)
  • 2020-11-29 12:54

    Try to use this

    table.setAutoCreateRowSorter(true);
    
    0 讨论(0)
提交回复
热议问题