Java JTable中的动态搜索过滤器
这个问题与这里提到的问题有关: [ 我制作了一个程序,可以读取txt文件并写入JTable。我还创建了一个方法,允许我动态搜索JTable的内容并显示与单词匹配的结果。 但是,我在JTable中写入的每个新条目都可以从过滤器中找到。但是,当我加载一个txt文件内容并尝试随后使用搜索过滤器时,结果无法显示。一旦我开始在文本字段中键入内容,JTable就会消失 我的搜索方法代码如下:Java JTable中的动态搜索过滤器,java,swing,jtable,rowfilter,documentlistener,Java,Swing,Jtable,Rowfilter,Documentlistener,这个问题与这里提到的问题有关: [ 我制作了一个程序,可以读取txt文件并写入JTable。我还创建了一个方法,允许我动态搜索JTable的内容并显示与单词匹配的结果。 但是,我在JTable中写入的每个新条目都可以从过滤器中找到。但是,当我加载一个txt文件内容并尝试随后使用搜索过滤器时,结果无法显示。一旦我开始在文本字段中键入内容,JTable就会消失 我的搜索方法代码如下: //Creation and functionality of the Search Field class Te
//Creation and functionality of the Search Field
class TestTableSortFilter extends JPanel {
public TableRowSorter < TableModel > rowSorter = new TableRowSorter < > (table.getModel());
public JTextField searchFilter = new JTextField();
public TestTableSortFilter() {
table.setRowSorter(rowSorter);
JPanel panel = new JPanel(new BorderLayout());
panel.add(new JLabel("Search:"),
BorderLayout.WEST);
panel.add(searchFilter, BorderLayout.CENTER);
setLayout(new BorderLayout());
add(panel, BorderLayout.SOUTH);
add(new JScrollPane(table), BorderLayout.CENTER);
searchFilter.getDocument().addDocumentListener(new DocumentListener() {
@Override
public void insertUpdate(DocumentEvent e) {
String text = searchFilter.getText();
if (text.trim().length() == 0) {
rowSorter.setRowFilter(null);
} else {
rowSorter.setRowFilter(RowFilter.regexFilter("(?i)" + text));
}
}
@Override
public void removeUpdate(DocumentEvent e) {
String text = searchFilter.getText();
if (text.trim().length() == 0) {
rowSorter.setRowFilter(null);
} else {
rowSorter.setRowFilter(RowFilter.regexFilter("(?i)" + text));
}
}
@Override
public void changedUpdate(DocumentEvent e) {
throw new UnsupportedOperationException("Not supported yet.");
}
});
} //end TestTableSortFilter
} //end class table sort & creating the sorter for Search
//搜索字段的创建和功能
类TestTableSortFilter扩展了JPanel{
public TableRowSorterrowSorter=新TableRowSorter<>(table.getModel());
public JTextField searchFilter=new JTextField();
公共TestTableSortFilter(){
表.设置行分拣机(行分拣机);
JPanel panel=newjpanel(newborderlayout());
添加(新的JLabel(“搜索:”),
边界布局(西);
panel.add(searchFilter,BorderLayout.CENTER);
setLayout(新的BorderLayout());
添加(面板,边界布局。南部);
添加(新的JScrollPane(表),BorderLayout.CENTER);
searchFilter.getDocument().addDocumentListener(新DocumentListener()){
@凌驾
公共作废插入更新(文档事件e){
String text=searchFilter.getText();
如果(text.trim().length()==0){
rowSorter.setRowFilter(空);
}否则{
rowSorter.setRowFilter(RowFilter.regexFilter(“(?i)”+文本));
}
}
@凌驾
公共作废移除更新(文档事件e){
String text=searchFilter.getText();
如果(text.trim().length()==0){
rowSorter.setRowFilter(空);
}否则{
rowSorter.setRowFilter(RowFilter.regexFilter(“(?i)”+文本));
}
}
@凌驾
公共作废更改日期(记录事件e){
抛出新的UnsupportedOperationException(“尚未支持”);
}
});
}//结束TestTablesPortFilter
}//结束类表排序&创建用于搜索的排序器
在哪个类上?我从txt文件读取的OpenData?那里有table.setModel(新的DefaultTableModel(col,0));行。它是应该更改的吗
试着这样做:
import java.awt.*;
import java.awt.event.*;
import javax.swing.*;
import javax.swing.event.*;
import javax.swing.table.*;
public class RowSorterTest {
private final String[] columnNames = {"Number", "Type", "IP", "Protocol", "Line"};
private final Object[][] data = {
{"aaa", "1", "", "", ""}, {"bbbbb", "", "", "", ""}
};
private final DefaultTableModel model = new DefaultTableModel(data, columnNames) {
@Override public Class<?> getColumnClass(int column) {
return getValueAt(0, column).getClass();
}
};
private final JTable table = new JTable(model);
private final TableRowSorter<TableModel> rowSorter = new TableRowSorter<>(model);
private final JTextField searchFilter = new JTextField();
private final JButton open = new JButton("open");
public JComponent makeUI() {
table.setRowSorter(rowSorter);
open.addActionListener(new OpenData());//end OpenData class
JPanel panel = new JPanel(new BorderLayout());
panel.add(new JLabel("Search:"), BorderLayout.WEST);
panel.add(searchFilter, BorderLayout.CENTER);
panel.add(open, BorderLayout.EAST);
searchFilter.getDocument().addDocumentListener(new DocumentListener() {
@Override
public void insertUpdate(DocumentEvent e) {
String text = searchFilter.getText();
System.out.println(text);
if (text.trim().length() == 0) {
rowSorter.setRowFilter(null);
} else {
rowSorter.setRowFilter(RowFilter.regexFilter("(?i)" + text));
}
table.repaint();
}
@Override
public void removeUpdate(DocumentEvent e) {
String text = searchFilter.getText();
if (text.trim().length() == 0) {
rowSorter.setRowFilter(null);
} else {
rowSorter.setRowFilter(RowFilter.regexFilter("(?i)" + text));
}
}
@Override
public void changedUpdate(DocumentEvent e) {
//not needed: throw new UnsupportedOperationException("Not supported yet.");
}
});
JPanel p = new JPanel(new BorderLayout());
p.add(new JScrollPane(table));
p.add(panel, BorderLayout.SOUTH);
return p;
}
class OpenData implements ActionListener {
@Override public void actionPerformed(ActionEvent e) {
// String line = null;
// try{
// File file = new File ("C:\\Inne\\PhoneData.txt");
// FileReader fr = new FileReader (file.getAbsoluteFile());
// BufferedReader br = new BufferedReader (fr);
// StringBuilder builder = new StringBuilder();
// while ((line = br.readLine()) != null) {
// builder.append(line);
// }
// String[] lineArray= builder.toString().split("/");
// table.setModel(new DefaultTableModel(columnNames, 0));
// for(String currentLine: lineArray){
// String[] dataArray = currentLine.split(";");
// ((DefaultTableModel)table.getModel()).addRow(dataArray);
// }
// br.close();
// }catch (IOException e3) {
// e3.printStackTrace();
// }//end catch
DefaultTableModel m = new DefaultTableModel(columnNames, 0);
//Dummy data
for (int i = 0; i < 5; i++) {
String[] dataArray = {"aa" + i, "", "", "", ""};
m.addRow(dataArray);
}
table.setModel(m);
rowSorter.setModel(m);
}//end action method
}
public static void main(String[] args) {
EventQueue.invokeLater(new Runnable() {
@Override public void run() {
createAndShowGUI();
}
});
}
public static void createAndShowGUI() {
JFrame f = new JFrame();
f.setDefaultCloseOperation(WindowConstants.EXIT_ON_CLOSE);
f.getContentPane().add(new RowSorterTest().makeUI());
f.setSize(320, 240);
f.setLocationRelativeTo(null);
f.setVisible(true);
}
}
import java.awt.*;
导入java.awt.event.*;
导入javax.swing.*;
导入javax.swing.event.*;
导入javax.swing.table.*;
公共级RowsterTest{
私有最终字符串[]columnNames={“编号”、“类型”、“IP”、“协议”、“行”};
私有最终对象[][]数据={
{“aaa”,“1”,“0”,“0”,“0},{“bbbbb”,“0”,“0”,“0”,“0}
};
私有最终DefaultTableModel=新的DefaultTableModel(数据、列名){
@重写公共类getColumnClass(int列){
返回getValueAt(0,列).getClass();
}
};
专用最终JTable表=新JTable(模型);
专用最终表格行分拣机行分拣机=新表格行分拣机(型号);
私有最终JTextField searchFilter=新JTextField();
私有最终JButton打开=新JButton(“打开”);
公共JComponent makeUI(){
表.设置行分拣机(行分拣机);
open.addActionListener(新建OpenData());//结束OpenData类
JPanel panel=newjpanel(newborderlayout());
添加(新JLabel(“搜索:”),BorderLayout.WEST);
panel.add(searchFilter,BorderLayout.CENTER);
面板。添加(打开,边界布局。东);
searchFilter.getDocument().addDocumentListener(新DocumentListener()){
@凌驾
公共作废插入更新(文档事件e){
String text=searchFilter.getText();
System.out.println(文本);
如果(text.trim().length()==0){
rowSorter.setRowFilter(空);
}否则{
rowSorter.setRowFilter(RowFilter.regexFilter(“(?i)”+文本));
}
表1.repaint();
}
@凌驾
公共作废移除更新(文档事件e){
String text=searchFilter.getText();
如果(text.trim().length()==0){
rowSorter.setRowFilter(空);
}否则{
rowSorter.setRowFilter(RowFilter.regexFilter(“(?i)”+文本));
}
}
@凌驾
公共作废更改日期(记录事件e){
//不需要:抛出新的UnsupportedOperationException(“尚未支持”);
}
});
JPanel p=newjpanel(newborderlayout());
p、 添加(新JScrollPane(表));
p、 添加(面板,边界布局。南部);
返回p;
}
类OpenData实现ActionListener{
@覆盖已执行的公共无效操作(ActionEvent e){
//字符串行=null;
//试一试{
//File File=新文件(“C:\\Inne\\PhoneData.txt”);
//FileReader fr=新的FileReader(file.getAbsoluteFile());
//BufferedReader br=新的BufferedReader(fr);
//StringBuilder=新的StringBuilder();
//而((line=br.readLine())!=null){
//builder.append(行);
// }
//字符串[]lineArray=builder.toString().split(“/”);
//table.setModel(新的DefaultTableModel(columnNames,0));
//用于(字符串currentLine:lineArray){
//字符串[]dataArray=currentLine.split(“;”);
//((DefaultTableModel)table.getModel()).addRow(dataArray);
// }
//br.close();
//}捕获(IOE3异常){
//e3.printStackTrace();
//}//end-catch
DefaultTableModel m=新的DefaultTableModel(columnNames,0);
//虚拟数据
对于(int i=0;i<5;i++){
字符串[]数据数组={“aa”+i,“,”“,”“,”“,”“};
m、 addRow(数据数组);
}
表2.setModel(m);
rowSorter.setModel(m);
}//端作用法