java JFileChooser 文件过滤

本文介绍了一个自定义文件过滤器的实现方法,该过滤器可用于Java Swing的JFileChooser组件中,以限制用户仅能选择特定类型的文件,例如Excel文件(.xls, .xlsx)。通过使用Hashtable来存储和管理文件扩展名,过滤器能够灵活地添加多种文件类型。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

/*
 * To change this template, choose Tools | Templates
 * and open the template in the editor.
 */
package invcompare;

import java.io.File;
import java.util.Enumeration;
import java.util.Hashtable;
import javax.swing.JFileChooser;
import javax.swing.filechooser.FileFilter;

/**
 *
 * @author luolai
 */
public class MyFileFilter extends FileFilter {

    private static String TYPE_UNKNOWN = "Type   Unknown ";
    private static String HIDDEN_FILE = "Hidden   File ";
    private Hashtable filters = null;
    private String description = null;
    private String fullDescription = null;
    private boolean useExtensionsInDescription = true;

    public MyFileFilter() {
        this.filters = new Hashtable();
    }

    public MyFileFilter(String extension) {
        this(extension, null);
    }

    public MyFileFilter(String extension, String description) {
        this();
        if (extension != null) {
            addExtension(extension);
        }
        if (description != null) {
            setDescription(description);
        }
    }

    public MyFileFilter(String[] filters) {
        this(filters, null);
    }

    public MyFileFilter(String[] filters, String description) {
        this();
        for (int i = 0; i < filters.length; i++) {
            //   add   filters   one   by   one 
            addExtension(filters[i]);
        }
        if (description != null) {
            setDescription(description);
        }
    }

    public boolean accept(File f) {
        if (f != null) {
            String extension = getExtension(f);
            if (extension != null && filters.get(getExtension(f)) != null) {
                return true;
            };
        }
        return false;
    }

    public String getExtension(File f) {
        if (f != null) {
            String filename = f.getName();
            int i = filename.lastIndexOf('.');
            if (i > 0 && i < filename.length() - 1) {
                return filename.substring(i + 1).toLowerCase();
            };
        }
        return null;
    }

    public void addExtension(String extension) {
        if (filters == null) {
            filters = new Hashtable(5);
        }
        filters.put(extension.toLowerCase(), this);
        fullDescription = null;
    }

    public String getDescription() {
        if (fullDescription == null) {
            if (description == null || isExtensionListInDescription()) {
                fullDescription = description == null ? "( " : description + "   ( ";
//   build   the   description   from   the   extension   list 
                Enumeration extensions = filters.keys();
                if (extensions != null) {
                    fullDescription += ". " + (String) extensions.nextElement();
                    while (extensions.hasMoreElements()) {
                        fullDescription += ",   " + (String) extensions.nextElement();
                    }
                }
                fullDescription += ") ";
            } else {
                fullDescription = description;
            }
        }
        return fullDescription;
    }

    public void setDescription(String description) {
        this.description = description;
        fullDescription = null;
    }

    public void setExtensionListInDescription(boolean b) {
        useExtensionsInDescription = b;
        fullDescription = null;
    }

    public boolean isExtensionListInDescription() {
        return useExtensionsInDescription;
    }

    public static void main(String[] args) {
        //使用方法
        String filePath = "";
        JFileChooser chooser = new JFileChooser();
        chooser.setCurrentDirectory(new File("."));
        //去掉显示所有文件这个过滤器。
        chooser.setAcceptAllFileFilterUsed(false);

        chooser.addChoosableFileFilter(new MyFileFilter("xls", "Excel Files"));
        chooser.addChoosableFileFilter(new MyFileFilter("xlsx", "Excel Files"));

        int returnVal = chooser.showSaveDialog(this);
        if (returnVal == JFileChooser.APPROVE_OPTION) {
            filePath = chooser.getSelectedFile().getAbsolutePath();
        }
        if (filePath.equals("")) {
            return false;
        }
    }
}


 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值