文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

从零开始学习 Java:简单易懂的入门指南之File类(二十九)

2023-09-30 11:55

关注

File类

1. File类

1.1 概述

java.io.File 类是文件和目录路径名的抽象表示,主要用于文件和目录的创建、查找和删除等操作。

1.2 构造方法

// 文件路径名String pathname = "D:\\aaa.txt";File file1 = new File(pathname); // 文件路径名String pathname2 = "D:\\aaa\\bbb.txt";File file2 = new File(pathname2); // 通过父路径和子路径字符串 String parent = "d:\\aaa"; String child = "bbb.txt"; File file3 = new File(parent, child);// 通过父级File对象和子路径字符串File parentDir = new File("d:\\aaa");String child = "bbb.txt";File file4 = new File(parentDir, child);

小贴士:

  1. 一个File对象代表硬盘中实际存在的一个文件或者目录。
  2. 无论该路径下是否存在文件或者目录,都不影响File对象的创建。

1.3 常用方法

获取功能的方法

API中说明:length(),表示文件的长度。但是File对象表示目录,则返回值未指定。

绝对路径和相对路径

public class FilePath {    public static void main(String[] args) {      // D盘下的bbb.java文件        File f = new File("D:\\bbb.java");        System.out.println(f.getAbsolutePath());      // 项目下的bbb.java文件        File f2 = new File("bbb.java");        System.out.println(f2.getAbsolutePath());    }}输出结果:D:\bbb.javaD:\idea_project_test4\bbb.java

判断功能的方法

方法演示,代码如下:

public class FileIs {    public static void main(String[] args) {        File f = new File("d:\\aaa\\bbb.java");        File f2 = new File("d:\\aaa");      // 判断是否存在        System.out.println("d:\\aaa\\bbb.java 是否存在:"+f.exists());        System.out.println("d:\\aaa 是否存在:"+f2.exists());      // 判断是文件还是目录        System.out.println("d:\\aaa 文件?:"+f2.isFile());        System.out.println("d:\\aaa 目录?:"+f2.isDirectory());    }}输出结果:d:\aaa\bbb.java 是否存在:trued:\aaa 是否存在:trued:\aaa 文件?:falsed:\aaa 目录?:true

创建删除功能的方法

方法演示,代码如下:

public class FileCreateDelete {    public static void main(String[] args) throws IOException {        // 文件的创建        File f = new File("aaa.txt");        System.out.println("是否存在:"+f.exists()); // false        System.out.println("是否创建:"+f.createNewFile()); // true        System.out.println("是否存在:"+f.exists()); // true     // 目录的创建      File f2= new File("newDir");        System.out.println("是否存在:"+f2.exists());// false        System.out.println("是否创建:"+f2.mkdir());// true        System.out.println("是否存在:"+f2.exists());// true// 创建多级目录      File f3= new File("newDira\\newDirb");        System.out.println(f3.mkdir());// false        File f4= new File("newDira\\newDirb");        System.out.println(f4.mkdirs());// true            // 文件的删除       System.out.println(f.delete());// true            // 目录的删除        System.out.println(f2.delete());// true        System.out.println(f4.delete());// false    }}

API中说明:delete方法,如果此File表示目录,则目录必须为空才能删除。

1.4 目录的遍历

public class FileFor {    public static void main(String[] args) {        File dir = new File("d:\\java_code");            //获取当前目录下的文件以及文件夹的名称。String[] names = dir.list();for(String name : names){System.out.println(name);}        //获取当前目录下的文件以及文件夹对象,只要拿到了文件对象,那么就可以获取更多信息        File[] files = dir.listFiles();        for (File file : files) {            System.out.println(file);        }    }}

小贴士:

调用listFiles方法的File对象,表示的必须是实际存在的目录,否则返回null,无法进行遍历。

1.5 综合练习

练习1:创建文件夹

​ 在当前模块下的aaa文件夹中创建一个a.txt文件

代码实现:

public class Test1 {    public static void main(String[] args) throws IOException {        //需求:在当前模块下的aaa文件夹中创建一个a.txt文件        //1.创建a.txt的父级路径        File file = new File("myfile\\aaa");        //2.创建父级路径        //如果aaa是存在的,那么此时创建失败的。        //如果aaa是不存在的,那么此时创建成功的。        file.mkdirs();        //3.拼接父级路径和子级路径        File src = new File(file,"a.txt");        boolean b = src.createNewFile();        if(b){            System.out.println("创建成功");        }else{            System.out.println("创建失败");        }    }}

练习2:查找文件(不考虑子文件夹)

​ 定义一个方法找某一个文件夹中,是否有以avi结尾的电影(暂时不需要考虑子文件夹)

代码示例:

public class Test2 {    public static void main(String[] args) {                File file = new File("D:\\aaa\\bbb");        boolean b = haveAVI(file);        System.out.println(b);    }        public static boolean haveAVI(File file){// D:\\aaa        //1.进入aaa文件夹,而且要获取里面所有的内容        File[] files = file.listFiles();        //2.遍历数组获取里面的每一个元素        for (File f : files) {            //f:依次表示aaa文件夹里面每一个文件或者文件夹的路径            if(f.isFile() && f.getName().endsWith(".avi")){                return true;            }        }        //3.如果循环结束之后还没有找到,直接返回false        return false;    }}

练习3:(考虑子文件夹)

​ 找到电脑中所有以avi结尾的电影。(需要考虑子文件夹)

代码示例:

public class Test3 {    public static void main(String[] args) {                findAVI();    }    public static void findAVI(){        //获取本地所有的盘符        File[] arr = File.listRoots();        for (File f : arr) {            findAVI(f);        }    }    public static void findAVI(File src){//"C:\\        //1.进入文件夹src        File[] files = src.listFiles();        //2.遍历数组,依次得到src里面每一个文件或者文件夹        if(files != null){            for (File file : files) {                if(file.isFile()){                    //3,判断,如果是文件,就可以执行题目的业务逻辑                    String name = file.getName();                    if(name.endsWith(".avi")){                        System.out.println(file);                    }                }else{                    //4,判断,如果是文件夹,就可以递归                    //细节:再次调用本方法的时候,参数一定要是src的次一级路径                    findAVI(file);                }            }        }    }}

练习4:删除多级文件夹

需求: 如果我们要删除一个有内容的文件夹
1.先删除文件夹里面所有的内容
2.再删除自己

代码示例:

public class Test4 {    public static void main(String[] args) {                File file = new File("D:\\aaa\\src");        delete(file);    }        public static void delete(File src){        //1.先删除文件夹里面所有的内容        //进入src        File[] files = src.listFiles();        //遍历        for (File file : files) {            //判断,如果是文件,删除            if(file.isFile()){                file.delete();            }else {                //判断,如果是文件夹,就递归                delete(file);            }        }        //2.再删除自己        src.delete();    }}

练习5:统计大小

​ 需求:统计一个文件夹的总大小

代码示例:

public class Test5 {    public static void main(String[] args) {               File file = new File("D:\\aaa\\src");        long len = getLen(file);        System.out.println(len);//4919189    }        public static long getLen(File src){        //1.定义变量进行累加        long len = 0;        //2.进入src文件夹        File[] files = src.listFiles();        //3.遍历数组        for (File file : files) {            //4.判断            if(file.isFile()){                //我们就把当前文件的大小累加到len当中                len = len + file.length();            }else{                //判断,如果是文件夹就递归                len = len + getLen(file);            }        }        return len;    }}

练习6:统计文件个数

需求:统计一个文件夹中每种文件的个数并打印。(考虑子文件夹)
打印格式如下:
txt:3个
doc:4个
jpg:6个

代码示例:

public class Test6 {    public static void main(String[] args) throws IOException {                File file = new File("D:\\aaa\\src");        HashMap<String, Integer> hm = getCount(file);        System.out.println(hm);    }        public static HashMap<String,Integer> getCount(File src){        //1.定义集合用来统计        HashMap<String,Integer> hm = new HashMap<>();        //2.进入src文件夹        File[] files = src.listFiles();        //3.遍历数组        for (File file : files) {            //4.判断,如果是文件,统计            if(file.isFile()){                //a.txt                String name = file.getName();                String[] arr = name.split("\\.");                if(arr.length >= 2){                    String endName = arr[arr.length - 1];                    if(hm.containsKey(endName)){                        //存在                        int count = hm.get(endName);                        count++;                        hm.put(endName,count);                    }else{                        //不存在                        hm.put(endName,1);                    }                }            }else{                //5.判断,如果是文件夹,递归                //sonMap里面是子文件中每一种文件的个数                HashMap<String, Integer> sonMap = getCount(file);                //hm:  txt=1  jpg=2  doc=3                //sonMap: txt=3 jpg=1                //遍历sonMap把里面的值累加到hm当中                Set<Map.Entry<String, Integer>> entries = sonMap.entrySet();                for (Map.Entry<String, Integer> entry : entries) {                    String key = entry.getKey();                    int value = entry.getValue();                    if(hm.containsKey(key)){                        //存在                        int count = hm.get(key);                        count = count + value;                        hm.put(key,count);                    }else{                        //不存在                        hm.put(key,value);                    }                }            }        }        return hm;    }}

后记
👉👉💕💕美好的一天,到此结束,下次继续努力!欲知后续,请看下回分解,写作不易,感谢大家的支持!! 🌹🌹🌹

来源地址:https://blog.csdn.net/m0_59230408/article/details/132294699

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯