当前位置: 首页 > 知识库问答 >
问题:

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

松和泰
2023-03-14

我已经尝试了很多方法,以“德语”样式在JTable中显示逗号而不是点。在我的JTable类中,我编写了一个方法,用于循环传递的结果集,以填充DefaultTableModel并直接返回模型或JTable。

如果我将一个BigDecimal转换为一个字符串,用逗号替换一个点,结果将在我的JTable中正确显示-但是我的排序序列不正确,因为值将被排序为字符串而不是BigDecimal...

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

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

谁有主意,如何以德文格式显示?

非常感谢!

这是我的班级:

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

共有2个答案

施知
2023-03-14

但是我的排序顺序不正确,因为这些值将被排序为字符串而不是BigDecimal。。。

不要在TableModel中存储字符串。存储大十进制数。

如果我将一个BigDecimal转换为字符串,以用逗号替换一个点,

格式化数据是渲染器的工作。有关如何重写渲染器的setValue(...)方法的简单示例,请查看Table FormatRenderer。

您还需要重写getGonnClass(...)方法以返回BigDecimal,以便执行适当的排序。

许远航
2023-03-14

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

问题的一小部分是您混淆了数据本身,即如何显示或呈现数据。

然而,恕我直言,主要的问题是您不能在表模型中重写get列类(int列类索引):我从来不信任向模型询问第一行单元格的类。如果getValueAt(0,1)返回null怎么办?回答:你会在getValueAt(0,1). getClass()调用一个NullPointerExc0019

现在,根据问题中的上下文,您无法提供适当的TableCellRenderer,因为您不知道结果集将提前返回哪个类。但是,您可以依赖“概念:编辑器和渲染器”中描述的默认行为,并覆盖getColumnClass(…)

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只是因为我在其他地方有代码,我懒得修改它。

 类似资料:
  • 问题内容: 给定以下数组,我想用点替换逗号: 我一直在尝试不同的方式,但是我不知道该怎么做。另外,我已将其作为DataFrame导入,但无法应用该函数: 有什么建议如何解决这个问题? 问题答案: 您需要分配的结果,你的工作早在操作不就地,除了可以使用或并用矢量化要做到这一点更快: 这里的关键是分配结果:

  • 我在“a-b-c”的形式下有工件id,我希望我的原型有一个像“a. b. c”这样的包。所以,我做以下几点: 但这样做会让我: [错误]无法执行目标组织。阿帕奇。专家插件:maven原型插件:3.1.2:generate(默认cli)在独立项目pom:java上。伊奥。IOException:文件名、目录名或卷标语法不正确 如果我把它取下来,一切都会好的。为什么?

  • 问题内容: 我需要不时动态地更改表和变量,因此我编写了这样的python方法: 但是,这导致语法错误异常。我尝试对其进行调试,因此我将变量打印在方法中,然后手动将其填充,并且可以正常工作。所以我不确定我在做什么错? 是因为我尝试使用表的替代品吗? 另外,我该如何调试mysqldb以便将替换查询打印为字符串? 问题答案: DB API中的参数替换仅适用于值-不适用于表或字段。您将需要使用普通的字符串

  • 基本上,我在Spring Boot中向控制器发送两个参数,一个是字符串,另一个是文件。在操作中,当我首先接收文件,然后接收字符串时,如下所示 一切都很好,我能够正确地访问字符串和文件。 但是当我改变参数的顺序时,就像这样 我研究了很多,但不能理解这种行为。

  • 在使用“number”类型和值“1,5”的输入发布表单后,浏览器(Chrome 43.0.2357.130,FF 38.0.5)发送带有点作为小数分隔符的数字,但输入具有属性lang=“cs”(在捷克共和国,我们使用十进制逗号),因此对于ASP。NETMVC的格式不正确。 如何设置浏览器(表单/输入)以发送用户真正填写的内容(在我的示例中为“1,5”)? 从浏览器发送的表单数据:

  • 任何关于下一步何去何从的帮助都将不胜感激。 下面是由Spring Bootinitializr生成的文件夹结构。我唯一改变的是使src成为源根。