如何在jTable中读取和搜索文件?

时间:2017-12-26 11:46:03

标签: java swing file search jtable

我想在此代码中执行的操作:点击搜索按钮后,它会显示file,然后将搜索值与file&内的数据相匹配;将在jTable

中显示搜索结果

我面临的问题:如果选择了GPA,那么它会显示A +,A-和&当我在给出另一个搜索值后再次按下搜索按钮时,该表只会在其中添加更多数据。

需要解决方案:我想只读取文件并仅在jTable中显示结果,而不是再次添加结果&再次。搜索按钮应该在GPA&中进行搜索。仅限类列。 &安培;当GPA被选为“A / B / C +”或“ - ”时,搜索结果应仅包含包含该特定GPA的数据。

注意: 我不想更改搜索选项。

我是JAVA的新手。所以任何形式的帮助将不胜感激! :)

Screenshot of the UI

private void srchBtnActionPerformed(java.awt.event.ActionEvent evt) {                                        

    //file read
    String filepath = "E:\\Netbeans workspace\\modified\\Project\\Info.txt";
    File file = new File(filepath);

    try {
        BufferedReader br = new BufferedReader(new FileReader(file));
        model = (DefaultTableModel)jTable1.getModel();

        Object[] tableLines = br.lines().toArray();

        for (int i = 0; i < tableLines.length; i++){
            String line = tableLines[i].toString().trim();
            String[] dataRow = line.split("/");
            model.addRow(dataRow);

        }

    } catch (Exception ex) {
        Logger.getLogger(ReceiverF.class.getName()).log(Level.SEVERE, null, ex);
    }

    //search from file
    String bGroupSrch = (String) jComboBoxBGroup.getSelectedItem();
    if(positiveRBtn.isSelected())
        bGroupSrch = bGroupSrch + "+";
    else if(negativeRBtn.isSelected())
        bGroupSrch = bGroupSrch + "-";

    String areaSrch = (String)jComboBoxArea.getSelectedItem();

    if (bgGroup.getSelection() != null) {

        filter(bGroupSrch);
        filter(areaSrch);
    } else {
        SrchEMsg sem = new SrchEMsg(this);
        sem.setVisible(true);
        sem.setDefaultCloseOperation(JDialog.DISPOSE_ON_CLOSE);
    }
}

//Filter Method
private void filter(String query){
    TableRowSorter<DefaultTableModel> tr= new TableRowSorter<DefaultTableModel>(model);
    jTable1.setRowSorter(tr);

    tr.setRowFilter(RowFilter.regexFilter(query));
}

1 个答案:

答案 0 :(得分:1)

  

该表只是在其中添加了更多数据。

当您开始搜索时:

model.setRowCount(0);

清除表格表格模型中的数据。

或者更简单的解决方案是不要一直重新加载数据。相反,您只需更改表使用的过滤器即可。

阅读Sorting and Filtering上的Swing教程中的部分。每次键入字符时,代码都会替换过滤器。

更改搜索选项后,您的代码将更改过滤器。