java - 在 JTable 中用逗号替换点会导致错误的排序顺序

标签 java swing sorting jtable number-formatting

我尝试了很多方法来以“德语”风格在 JTable 中显示逗号而不是点。在我的 JTable-Class 中,我编写了一个方法,用于循环传递的 ResultSet 来填充 DefaultTableModel 并直接返回模型或 JTable。

如果我将 BigDecimal 转换为字符串以用逗号替换点,结果将在我的 JTable 中正确显示 - 但随后我的排序序列不正确,因为这些值将被排序为字符串而不是大十进制...

另一个解决方案是直接通过 SQL 语句进行排序,并在单击行标题时动态更改排序顺序 - 但这对我来说不是最好的解决方案,因为我的表的内容是由执行大量查询,这需要花费大量时间。

我尝试设置 JTable 的区域设置,但没有任何效果。

有人知道如何以德语格式显示吗?

非常感谢!

这是我的类(class):

import java.math.BigDecimal;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.sql.SQLException;
import java.util.Locale;
import java.util.Vector;

import javax.swing.JTable;
import javax.swing.RowSorter;
import javax.swing.table.DefaultTableModel;
import javax.swing.table.TableModel;
import javax.swing.table.TableRowSorter;


public class MyJTable extends JTable {  

private static final long serialVersionUID = 1L;    

public MyJTable(){      
   this.setLocale(Locale.GERMANY);  
}

public MyJTable(ResultSet rs) throws SQLException{        
            DefaultTableModel model = this.getTableModel(rs);
            this.setModel(model);
            RowSorter<TableModel> sorter = new TableRowSorter<TableModel>(model);
            this.setRowSorter(sorter);
            this.setLocale(Locale.GERMANY);
}

public DefaultTableModel getTableModel(ResultSet rs) throws SQLException{

    ResultSetMetaData metaData = rs.getMetaData();
    // names of columns
    Vector<String> columnNames = new Vector<String>();
    int columnCount = metaData.getColumnCount();
    for (int column = 1; column <= columnCount; column++) {
        columnNames.add(metaData.getColumnName(column));
    }
    // data of the table
    Vector<Vector<Object>> data = new Vector<Vector<Object>>();
    String bigdecimal=null;
    Object obigdecimal;
    while (rs.next()) {
        Vector<Object> vector = new Vector<Object>();
        for (int columnIndex = 1; columnIndex <= columnCount; columnIndex++) {

            if     (metaData.getColumnClassName(columnIndex).equals("java.math.BigDecimal")){
                bigdecimal=rs.getString(columnIndex);
                if (bigdecimal!=null){
                bigdecimal=bigdecimal.replace(".",",");
                obigdecimal=bigdecimal;
                vector.add(obigdecimal);
                }               
            }
            else
            {
            vector.add(rs.getObject(columnIndex));
            }               
          }
        data.add(vector);
}

    return new DefaultTableModel(data, columnNames){

        private static final long serialVersionUID = 1L;

            public Class getColumnClass(int column) {
                Class returnValue=Object.class;
                try{
                if ((column >= 0) && (column < getColumnCount())) {
                  returnValue = getValueAt(0, column).getClass();
                } else {
                  returnValue = Object.class;
                }                     
                }
                catch(Exception e){}                    
                return returnValue;
              }
            };      
    }   
}

最佳答案

Replace point with comma in a JTable causes a wrong sorting-sequence

问题的一小部分是您混淆了数据本身关于如何显示或渲染的信息。

但是恕我直言,主要问题是你不覆盖 getColumnClass(int columnIndex)在你的表模型中:我永远不会相信向模型询问第一行单元格的类。如果 getValueAt(0,1) 返回 null 会怎样?答案:您将在 getValueAt(0,1).getClass() 调用中收到 NullPointerException

现在,鉴于您问题中的上下文,您无法提供适当的 TableCellRenderer,因为您不知道结果集会事先返回哪个类。但是,您可以依赖 Concepts: Editor and Renderers 中描述的默认行为。并重写 getColumnClass(...) 方法以使用 ResultSetMetaData 返回正确的类如下:

public TableModel getTableModel(ResultSet resultSet) throws SQLException {    
    ResultSetMetaData metaData = resultSet.getMetaData();        

    int columnCount = metaData.getColumnCount(); // columns number
    String[] columnNames = new String[columnCount];
    final Class[] columnClasses = new Class[columnCount];

    for (int i = 1; i <= columnCount; i++) {
        columnNames[i-1] = metaData.getColumnName(i); // fill columns names
        try {
            columnClasses[i-1] = Class.forName(metaData.getColumnClassName(i)); // fill column classes
        } catch (ClassNotFoundException ex) {
            // Log the exception here
        }
    }

    resultSet.last();
    int rowCount = resultSet.getRow(); // get rows number
    resultSet.beforeFirst();

    Object[][] data = new Object[rowCount][columnCount];
    int currentRow = 0;
    while (resultSet.next()) {
        for (int currentColumn = 1; currentColumn <= columnCount; currentColumn++) {
            data[currentRow][currentColumn - 1] = resultSet.getObject(currentColumn); // fill data set
         }
         currentRow++;
    }

    TableModel model = new DefaultTableModel(data, columnNames) {
        @Override
        public Class<?> getColumnClass(int columnIndex) {
            return columnClasses[columnIndex];
        }
    }
    return model;    
}

注意:使用Object[]而不是Vector只是因为我有代码somewhere else而且我也懒得修改了。

关于java - 在 JTable 中用逗号替换点会导致错误的排序顺序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28406959/

相关文章:

java - 如何修复 “cannot find symbol error”?

java - 如何将子菜单添加到 MenuItem

c - 冒泡排序示例

java - 将零替换为单词中的字母 "o"

java - 来自 ACTION_IMAGE_CAPTURE 的图像已旋转

java - 如何在 Java 中更改实际 JButton 的颜色?不是背景也不是文字

java - 当我在 JPanel 变得可见后对其进行修改时,paintComponent 在 componentResized 之前被调用

python - 我怎样才能用python中列表的顺序对字典进行排序

arrays - 以有效的方式排序和合并两个数组?

java - 使用传递的对象而不是存储的项调用 HashSet 相等性