如何从对象中的某些列而不是所有列创建表?这是所需的输出:
ID|Author|Messages
----------------------------
2 |Alice | My first message
5 |Alice | My second message
6 |Bob | Hello
这是对象。
private String[] columnNames
= {"ID","Author", "HideThis", "Messages"};
private Object[][] data = {
{"2", "Alice", "Hide this", "My first message"},
{"5", "Alice", "Hide this", "My second message"},
{"6", "Bob", "Hide this", "Hello"}
};
private DefaultTableModel model = new DefaultTableModel(data, columnNames);
我是否必须创建新的数据对象并仅复制相关列,或者是否可以说columnSetHidden(2)?
答案 0 :(得分:1)
DefaultTableModel model = new DefaultTableModel(ProcessArray(data,1),columnNames);
public Object[][] ProcessArray(Object[][] arr,int colindex) {
List points = Arrays.asList(arr);
for (int i = 0; i < arr.length; i++) {
for (int j = 0; j < arr[i].length; j++) {
points.remove(arr[i][colindex]);
}
}
Object[][] returnData = (Object[][]) points.toArray();
return returnData;
}
DefaultTableModel
中没有Api规范删除column
,但您可以customize
您的二维数组并删除所需的列。然后将处理过的数组传递给DefaultTableModel
的构造函数。但是,您仍需要更改列名称。