java gui 文件操作:创建与删除

Wesley13
• 阅读 589

文件操作:创建与删除

package com.wt010.file;

import java.awt.BorderLayout;
import java.awt.FlowLayout;
import java.awt.GridLayout;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.io.File;
import java.io.IOException;

import javax.swing.JButton;
import javax.swing.JComboBox;
import javax.swing.JFrame;
import javax.swing.JOptionPane;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JTextArea;
import javax.swing.JTextField;

/**
 * @author konecms
 * @date 2018年1月31日 下午5:02:24
 * 
 */
public class FileCreateAndDeleteUtil extends JFrame implements ActionListener{

    private JButton btnCreate,btnDelete;
    private JTextField txtFile;
    private JComboBox cmb;
    public FileCreateAndDeleteUtil() {
        // TODO Auto-generated constructor stub
        init(); 
    }
    public void init() {
        fr();
    }
    public void fr() {
        this.setTitle("文件创建与删除"); 
        this.setResizable(false);
        this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
        this.setLocationRelativeTo(null);
        BorderLayout bl=new BorderLayout();
        FlowLayout fl=new FlowLayout();
        GridLayout gl=new GridLayout(2,1);
        JPanel jp1=new JPanel();
        JPanel jp2=new JPanel();
        this.setLayout(bl);
        jp1.setLayout(fl);
        jp2.setLayout(fl);
         
        
        getContentPane().add("North",jp1);
        getContentPane().add("Center",jp2);
        cmb=new JComboBox();
        File[] files=File.listRoots();
        for(int i=0;i<files.length;i++) { 
            if(!files[i].toString().equals("C:\\")&&!files[i].toString().equals("D:\\"))
            cmb.addItem(files[i]);
        }
          jp1.add(cmb);
          txtFile=new JTextField(20);
          jp1.add(txtFile);
          btnCreate=new JButton("创建文件");btnCreate.addActionListener(this);
          btnDelete=new JButton("删除文件");btnDelete.addActionListener(this);
         jp1.add(btnCreate);jp1.add(btnDelete);
         
         JTextArea ta=new JTextArea(15,40);
         JScrollPane sp=new JScrollPane(ta);
         jp2.add(sp);
    }

    public void actionPerformed(ActionEvent e) {
        // TODO Auto-generated method stub
        Object source=e.getSource();
        String filename=txtFile.getText();
        String root=cmb.getSelectedItem().toString();
        
        if(filename.equals("")) {
            JOptionPane.showMessageDialog(this, "请输入需要文件或目录名称 。 "); 
            return;
        }
         filename=root+filename;

        if(source==btnDelete) {
            boolean bl=delete(filename);
            if(bl)
                JOptionPane.showMessageDialog(this, "删除成功 ! "); 
            else 
                JOptionPane.showMessageDialog(this, "删除失败 ! "); 
        }
        if(source==btnCreate) {
            File file=new File(filename); 
            if(file.exists()) {
                JOptionPane.showMessageDialog(this, "文件已经存在 。");
                return;
            }
            try {
                file.createNewFile();
            } catch (IOException e1) {
                // TODO Auto-generated catch block
                e1.printStackTrace();
            }
        }
    }
    public boolean delete(String filename) {
        File file=new File(filename);
        if(!file.exists()) { 
            return false;
        }
        if(file.isDirectory()) {
            return deleteDirectory(filename);
        }
        if(file.isFile()) {
            return deleteFile(filename);
        }
        return false;
    }
    public boolean deleteDirectory(String dirFile2) {
        File file=new File(dirFile2);
        File[] dirFile=file.listFiles();
        for(int i=0;i<dirFile.length;i++) {
            if(dirFile[i].isFile()) {
                deleteFile(dirFile[i].getAbsolutePath());
            }
            if(dirFile[i].isDirectory()) {
                deleteDirectory(dirFile[i].getAbsolutePath());
            }
        }
        if(file.delete()) {
            return true;
        }
        return false;
        
        
    }
    public boolean deleteFile(String filename) {
        File file=new File(filename);
        if(file.delete())
            return true;
        else
            return false;
    }
    
    public static void main(String[] args) {
        FileCreateAndDeleteUtil util=new FileCreateAndDeleteUtil();
        util.setVisible(true);
        util.pack();
    }
}
点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
6个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Wesley13 Wesley13
3年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
3年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Stella981 Stella981
3年前
Docker 部署SpringBoot项目不香吗?
  公众号改版后文章乱序推荐,希望你可以点击上方“Java进阶架构师”,点击右上角,将我们设为★“星标”!这样才不会错过每日进阶架构文章呀。  !(http://dingyue.ws.126.net/2020/0920/b00fbfc7j00qgy5xy002kd200qo00hsg00it00cj.jpg)  2
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
1年前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这