zoukankan      html  css  js  c++  java
  • Java显示指定类型的文件

    文件作为存储数据的单元,会根据数据类型产生很多分类,也就是所谓的文件类型。在对数据文件进行操作时,常常需要根据不同的文件类型来作不同的处理。本实例实现的是读取文件夹指定类型的文件并显示到表格控件中。这对于项目开发中的文件分类起到了抛砖引玉的作用。

    思路分析:

    1. 因为是窗体应用,首先看视图层。需要一个按钮控件JButton用来选择文件夹;需要一个标签控件JLabel用来显示选择的路径;需要一个标签控件JLabel提示用户输入什么;需要一个文本框控件JTextField供用户输入文件类型;需要一个表格控件JTable显示选中目录下指定类型的文件。
    2. 对于按钮控件,为其绑定事件处理方法,在该方法中首先创建JFileChooser文件选择器对象,为该对象设置选择器的过滤器,即通过JFileChoose类的setFileSelectionMode()方法设定只能选择路径,然后执行showDialog()方法,再使用JFileChooser类的getSelectedFile()方法获取选中路径,赋值给一个File型变量,使用toString()方法将该路径显示在标签中,最后获取过滤后的符合条件的文件数组。
    3. 对于文本框控件,一旦里面的文字发生变化,就要重新对选中路径中的文件进行过滤,所以通过JTextField类的addCaretListener()方法为其绑定事件处理方法,在该方法中获取过滤后的符合条件的文件数组。
    4. 因为按钮控件和文本框控件都要实现过滤及显示,故可以将过滤及显示单独作为一个方法,在该方法中首先判断当前路径是否为空,若不为空则使用File类的listFiles()方法获取符合条件的文件数组,赋值给一个File型数组,然后使用JTable类的getModel()方法获取表格的数据模型,使用DefaultTableModel类的setRowCount()方法先将表格清空,然后使用foreach()循环遍历文件数组,在循环中使用Object[]数组创建表格行数据,调用File类的getName()方法获取文件名,length()方法获取文件大小,lastModified()方法获取修改日期,最后使用DefaultTableModel类的addRow()方法添加行数据到表格模型。

    代码如下:

    import java.awt.BorderLayout;
    import java.awt.EventQueue;
    import java.awt.GridBagConstraints;
    import java.awt.GridBagLayout;
    import java.awt.Insets;
    import java.awt.event.ActionEvent;
    import java.awt.event.ActionListener;
    import java.io.File;
    import java.sql.Date;
    
    import javax.swing.JButton;
    import javax.swing.JFileChooser;
    import javax.swing.JFrame;
    import javax.swing.JLabel;
    import javax.swing.JPanel;
    import javax.swing.JScrollPane;
    import javax.swing.JTable;
    import javax.swing.JTextField;
    import javax.swing.border.EmptyBorder;
    import javax.swing.event.CaretEvent;
    import javax.swing.event.CaretListener;
    import javax.swing.table.DefaultTableModel;
    
    public class ListCustomTypeFile extends JFrame {
        /**
         * 
         */
        private static final long serialVersionUID = -6263975104443132420L;
    
        /**
         * 自定义扩展名过滤器
         * 
         * @author 李钟尉
         */
        private final class CustomFilter implements java.io.FileFilter {
            @Override
            public boolean accept(File pathname) {
                // 获取用户设置的指定扩展名
                String extName = extNameField.getText();
                if (extName == null || extName.isEmpty())
                    return false;
                if (!extName.startsWith("."))// 判断扩展名前缀
                    extName = "." + extName;// 完事扩展名前缀
                extName = extName.toLowerCase();
                // 判断扩展名与过滤文件名是否符合要求
                if (pathname.getName().toLowerCase().endsWith(extName))
                    return true;
                return false;
            }
        }
        
        private JPanel contentPane;
        private JTextField extNameField;
        private JTable table;
        private File dir;
        private JLabel label;
        
        /**
         * Launch the application.
         */
        public static void main(String[] args) {
            EventQueue.invokeLater(new Runnable() {
                public void run() {
                    try {
                        ListCustomTypeFile frame = new ListCustomTypeFile();
                        frame.setVisible(true);
                    } catch (Exception e) {
                        e.printStackTrace();
                    }
                }
            });
        }
        
        /**
         * Create the frame.
         */
        public ListCustomTypeFile() {
            setTitle("显示指定类型的文件");
            setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
            setBounds(100, 100, 450, 300);
            contentPane = new JPanel();
            contentPane.setBorder(new EmptyBorder(5, 5, 5, 5));
            contentPane.setLayout(new BorderLayout(0, 0));
            setContentPane(contentPane);
            
            JPanel panel = new JPanel();
            contentPane.add(panel, BorderLayout.NORTH);
            GridBagLayout gbl_panel = new GridBagLayout();
            gbl_panel.columnWidths = new int[] { 93, 54, 0 };
            gbl_panel.rowHeights = new int[] { 23, 0, 0 };
            gbl_panel.columnWeights = new double[] { 0.0, 1.0, Double.MIN_VALUE };
            gbl_panel.rowWeights = new double[] { 0.0, 0.0, Double.MIN_VALUE };
            panel.setLayout(gbl_panel);
            
            JButton button = new JButton("选择文件夹");
            button.addActionListener(new ActionListener() {
                public void actionPerformed(ActionEvent e) {
                    do_button_actionPerformed(e);
                }
            });
            GridBagConstraints gbc_button = new GridBagConstraints();
            gbc_button.anchor = GridBagConstraints.NORTH;
            gbc_button.gridx = 0;
            gbc_button.gridy = 0;
            panel.add(button, gbc_button);
            
            label = new JLabel("文件夹");
            GridBagConstraints gbc_label = new GridBagConstraints();
            gbc_label.fill = GridBagConstraints.HORIZONTAL;
            gbc_label.gridx = 1;
            gbc_label.gridy = 0;
            panel.add(label, gbc_label);
            
            JLabel label_1 = new JLabel("输入指定文件扩展名称:");
            GridBagConstraints gbc_label_1 = new GridBagConstraints();
            gbc_label_1.anchor = GridBagConstraints.EAST;
            gbc_label_1.insets = new Insets(0, 0, 0, 5);
            gbc_label_1.gridx = 0;
            gbc_label_1.gridy = 1;
            panel.add(label_1, gbc_label_1);
            
            extNameField = new JTextField();
            extNameField.addCaretListener(new CaretListener() {
                public void caretUpdate(CaretEvent e) {
                    do_extNameField_caretUpdate(e);
                }
            });
            extNameField.setText(".gif");
            GridBagConstraints gbc_extNameField = new GridBagConstraints();
            gbc_extNameField.insets = new Insets(0, 0, 5, 0);
            gbc_extNameField.fill = GridBagConstraints.HORIZONTAL;
            gbc_extNameField.gridx = 1;
            gbc_extNameField.gridy = 1;
            panel.add(extNameField, gbc_extNameField);
            extNameField.setColumns(10);
            
            JScrollPane scrollPane = new JScrollPane();
            contentPane.add(scrollPane, BorderLayout.CENTER);
            
            table = new JTable();
            table.setAutoResizeMode(JTable.AUTO_RESIZE_OFF);
            table.setModel(new DefaultTableModel(new Object[][] {}, new String[] {"文件名称", "文件大小","修改日期" }) {
                /**
                         * 
                         */
                        private static final long serialVersionUID = 5274214559103654856L;
                boolean[] columnEditables = new boolean[] { false, false, false };
                
                public boolean isCellEditable(int row, int column) {
                    return columnEditables[column];
                }
            });
            table.getColumnModel().getColumn(0).setPreferredWidth(220);
            table.getColumnModel().getColumn(1).setPreferredWidth(85);
            table.getColumnModel().getColumn(2).setPreferredWidth(110);
            scrollPane.setViewportView(table);
        }
        
        /**
         * 选择文件夹按钮的事件处理方法
         * 
         * @param e
         */
        protected void do_button_actionPerformed(ActionEvent e) {
            JFileChooser chooser = new JFileChooser();// 创建文件选择器
            // 设置选择器的过滤器
            chooser.setFileSelectionMode(JFileChooser.DIRECTORIES_ONLY);
            chooser.showDialog(this, null);
            dir = chooser.getSelectedFile();
            getLabel().setText(dir.toString());
            // 获取过滤后的符合条件的文件数组
            listFiles();
        }
        
        /**
         * 显示文件夹中的文件
         */
        private void listFiles() {
            if (dir == null)
                return;
            // 获取符合条件的文件数组
            File[] files = dir.listFiles(new CustomFilter());
            // 获取表格的数据模型
            DefaultTableModel model = (DefaultTableModel) table.getModel();
            model.setRowCount(0);
            for (File file : files) {// 遍历文件数组
                // 创建表格行数据
                Object[] row = { file.getName(), file.length(),
                        new Date(file.lastModified()) };
                model.addRow(row);// 添加行数据到表格模型
            }
        }
        
        protected void do_extNameField_caretUpdate(CaretEvent e) {
            listFiles();
        }
        
        protected JLabel getLabel() {
            return label;
        }
    }
    

      效果如图:

  • 相关阅读:
    Qt QApplication 类简介--Qt 类简介专题(四)
    回调函数
    C++类型转换总结
    Debug Error
    C++回调函数(callback)的使用
    Nokia5230连接电脑无线上网
    photoshop cs6\cs5找不到扫描仪的解决办法(Twain_32.8BA补丁下载)
    UML类图几种关系的总结
    实现单点登录
    poj 1151Atlantis线段树求矩形面积并解题报告
  • 原文地址:https://www.cnblogs.com/cysolo/p/3570424.html
Copyright © 2011-2022 走看看