Java学习——IO流总结(一)

本文详细介绍了Java中的File类,包括其构造方法、绝对路径与相对路径的使用,以及创建、删除文件和目录的方法。通过实例演示了如何创建多级目录、删除文件及递归删除文件夹。此外,还讲解了File类的判断和获取功能,如判断文件或目录的存在、类型,以及获取路径和名称等。最后提供了两个实战练习,分别展示了如何删除多级文件夹和统计文件夹中各类型文件的数量。
摘要由CSDN通过智能技术生成

花了几天时间,过了下Java基础语法的IO流部分,做下总结吧,供自己以后参考!!!!!!!!!

第一部分——File类

  • 它是文件和目录路径名的抽象表示

  • 文件和目录是可以通过File封装成对象的

  • 对于File而言,其封装的并不是一个真正存在的文件,仅仅是一个路径名而已.它可以是存在的,也可以是不存在的.将来是要通过具体的操作把这个路径的内容转换为具体存在的

构造方法

File file= new File("java.txt");

在JAVA当前项目下创建一个txt文件!!!!!

  • 绝对路径

    是一个完整的路径,从盘符开始

     File file1 = new File("D:\\itheima\\a.txt");//绝对路径,从盘符开始!!
  • 相对路径

    是一个简化的路径,相对当前项目下的路径

File file2 = new File("a.txt");
File file3 = new File("模块名\\a.txt");//从当前项目根目录开始

类方法

public boolean createNewFile()   当具有该名称的文件不存在时,创建一个由该抽象路径名命名的新空文件

  //需求1:我要在E:\\itcast目录下创建一个文件java.txt
        File f1 = new File("E:\\itcast\\java.txt");
        System.out.println(f1.createNewFile());
    

 public boolean mkdir()     创建由此抽象路径名命名的目录

 

//需求2:我要在E:\\itcast目录下创建一个目录JavaSE
        File f2 = new File("E:\\itcast\\JavaSE");
        System.out.println(f2.mkdir());

 public boolean mkdirs()    创建由此抽象路径名命名的目录,包括任何必需但不存在的父目录

需求3:我要在E:\\itcast目录下创建一个多级目录JavaWEB\\HTML
        File f3 = new File("E:\\itcast\\JavaWEB\\HTML");
//        System.out.println(f3.mkdir());
        System.out.println(f3.mkdirs());

 

public boolean delete()    删除由此抽象路径名表示的文件或目录

        File f1 = new File("E:\\itcast\\java.txt");
        //需求1:在当前模块目录下创建java.txt文件
        File f1 = new File("myFile\\java.txt");
//        System.out.println(f1.createNewFile());

        //需求2:删除当前模块目录下的java.txt文件
        System.out.println(f1.delete());

 

File类判断和获取功能【应用】

判断功能

public boolean isDirectory()     测试此抽象路径名表示的File是否为目录

public boolean isFile()      测试此抽象路径名表示的File是否为文件

public boolean exists()    测试此抽象路径名表示的File是否存在

 

 获取功能

 public String getPath()     将此抽象路径名转换为路径名字符串

public String getName()   返回由此抽象路径名表示的文件或目录的名称

public File[] listFiles()      返回此抽象路径名表示的目录中的文件和目录的File对象数组

     //创建一个File对象
        File f = new File("myFile\\java.txt");

//        public boolean isDirectory():测试此抽象路径名表示的File是否为目录
//        public boolean isFile():测试此抽象路径名表示的File是否为文件
//        public boolean exists():测试此抽象路径名表示的File是否存在
        System.out.println(f.isDirectory());
        System.out.println(f.isFile());
        System.out.println(f.exists());

 

 

File类练习一:删除一个多级文件

 

public class Test2 {
    public static void main(String[] args) {
        //练习一:删除一个多级文件夹
        //delete方法
        //只能删除文件和空文件夹.
        //如果现在要删除一个有内容的文件夹?
        //先删掉这个文件夹里面所有的内容.
        //最后再删除这个文件夹

        File src = new File("C:\\Users\\apple\\Desktop\\src");
        deleteDir(src);
    }
  
	//1.定义一个方法,接收一个File对象
    private static void deleteDir(File src) {
        //先删掉这个文件夹里面所有的内容.
        //递归 方法在方法体中自己调用自己.
        //注意: 可以解决所有文件夹和递归相结合的题目
        //2.遍历这个File对象,获取它下边的每个文件和文件夹对象
        File[] files = src.listFiles();
        //3.判断当前遍历到的File对象是文件还是文件夹
        for (File file : files) {
            //4.如果是文件,直接删除
            if(file.isFile()){
                file.delete();
            }else{
                //5.如果是文件夹,递归调用自己,将当前遍历到的File对象当做参数传递
                deleteDir(file);//参数一定要是src文件夹里面的文件夹File对象
            }
        }
        //6.参数传递过来的文件夹File对象已经处理完成,最后直接删除这个空文件夹
        src.delete();
    }

}

 

 File类练习二:统计一个文件夹下的每种文件个数

        //统计一个文件夹中,每种文件出现的次数.
        //统计 --- 定义一个变量用来统计. ---- 弊端:同时只能统计一种文件
        //利用map集合进行数据统计,键 --- 文件后缀名  值 ----  次数

        File file = new File("filemodule");
        HashMap<String, Integer> hm = new HashMap<>();
        getCount(hm, file);
        System.out.println(hm);
    }
  
	//1.定义一个方法,参数是HashMap集合用来统计次数和File对象要统计的文件夹
    private static void getCount(HashMap<String, Integer> hm, File file) {
      	//2.遍历File对象,获取它下边的每一个文件和文件夹对象
        File[] files = file.listFiles();
        for (File f : files) {
          	//3.判断当前File对象是文件还是文件夹
            if(f.isFile()){
              	//如果是文件,判断这种类型文件后缀名在HashMap集合中是否出现过
                String fileName = f.getName();
                String[] fileNameArr = fileName.split("\\.");
                if(fileNameArr.length == 2){
                    String fileEndName = fileNameArr[1];
                    if(hm.containsKey(fileEndName)){
                        //出现过,获取这种类型文件的后缀名出现的次数,对其+1,在存回集合中
                        Integer count = hm.get(fileEndName);
                        //这种文件又出现了一次.
                        count++;
                        //把已经出现的次数给覆盖掉.
                        hm.put(fileEndName,count);
                    }else{
                        // 没出现过,将这种类型文件的后缀名存入集合中,次数存1
                        hm.put(fileEndName,1);
                    }
                }
            }else{
              //如果是文件夹,递归调用自己,HashMap集合就是参数集合,File对象是当前文件夹对象代码实现
                getCount(hm,f);
            }
        }

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值