删除或隐藏单元格中的值

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了删除或隐藏单元格中的值相关的知识,希望对你有一定的参考价值。

有没有办法隐藏或删除某个单元格或整列的值?如果你看一下这张照片:

Table image

你会发现,在将模拟数据添加到表格时,我非常有创意。

除了所有的笑话,我想从Priority列中删除所有值,因此只有彩色单元格。可能吗?也许迭代整个列并将值设置为null?只是一个没有实现计划的想法......

编辑

我的细胞渲染器:

public Component getTableCellRendererComponent(JTable table, Object value, boolean isSelected, boolean hasFocus,
        int row, int column) {
    Component cell = super.getTableCellRendererComponent(table, value, isSelected, hasFocus, row, column);

    if(value.equals("1")) { // red
        cell.setBackground(Color.RED);
        cell.setForeground(Color.WHITE);
    } else if (value.equals("2")) { // yellow
        cell.setBackground(Color.ORANGE);
        cell.setForeground(Color.WHITE);
    } else if (value.equals("3")) { // green
        cell.setBackground(Color.GREEN);
        cell.setForeground(Color.WHITE);
    } else { // white
        cell.setBackground(Color.WHITE);
        cell.setForeground(Color.GRAY);
    }

    return cell;
}

将渲染器分配给表:

TableColumn tblColumn = this.tblTodo.getColumnModel().getColumn(1);
    tblColumn.setCellRenderer(new PriorityColumnCellRenderer());
答案

您可以在渲染器的value方法中将超级方法调用中的getTableCellRendererComponent(...)值更改为空字符串:""

Component cell = super.getTableCellRendererComponent(table, "", isSelected, 
        hasFocus, row, column);

例如,

public Component getTableCellRendererComponent(JTable table, Object value, boolean isSelected, boolean hasFocus,
        int row, int column) {
    Component cell = super.getTableCellRendererComponent(table, "", isSelected, 
        hasFocus, row, column);

    if(value.equals("1")) { // red
        cell.setBackground(Color.RED);
        cell.setForeground(Color.WHITE);
    } else if (value.equals("2")) { // yellow
        cell.setBackground(Color.ORANGE);
        cell.setForeground(Color.WHITE);
    } else if (value.equals("3")) { // green
        cell.setBackground(Color.GREEN);
        cell.setForeground(Color.WHITE);
    } else { // white
        cell.setBackground(Color.WHITE);
        cell.setForeground(Color.GRAY);
    }
    return cell;
}
另一答案

找到答案。

超类中有一种方法:

super.setValue("myValue");

就我而言,这将是这样的:

super.setValue(null);

但是在检查值之后需要调用它。最终代码:

编辑

public Component getTableCellRendererComponent(JTable table, Object value, boolean isSelected, boolean hasFocus,
        int row, int column) {
    Component cell = super.getTableCellRendererComponent(table, value, isSelected, hasFocus, row, column);

    if(value.equals("1")) { // red
        cell.setBackground(Color.RED);
        cell.setForeground(Color.WHITE);
        super.setValue(null);
    } else if (value.equals("2")) { // yellow
        cell.setBackground(Color.ORANGE);
        cell.setForeground(Color.WHITE);
        super.setValue(null);
    } else if (value.equals("3")) { // green
        cell.setBackground(Color.GREEN);
        cell.setForeground(Color.WHITE);
        super.setValue(null);
    } else { // white
        cell.setBackground(Color.WHITE);
        cell.setForeground(Color.GRAY);
        super.setValue(null);
    }

    return cell;
}

编辑

为了简单起见,我使用了Hovercraft Full Of Eels的答案

以上是关于删除或隐藏单元格中的值的主要内容,如果未能解决你的问题,请参考以下文章

从单元格中的超级视图中删除视图

从excel vba的列中的所有单元格中删除不需要的字符

根据另一个单元格中的值自动填充 x 行的代码

无法访问表视图单元格中 Struct 中的值。阅读下面截图中描述的代码

VBA:如何找到同一行中的下一个单元格(不包括隐藏单元格)

根据数据框中单元格中的值将颜色应用于单元格