JavaEE 初阶篇-深入了解 File 文件操作(实现文件搜索、非空文件夹删除)

🔥博客主页: 【小扳_-CSDN博客】
❤感谢大家点赞👍收藏⭐评论✍

文章目录

        1.0 File 文件概述

        2.0 创建 File 类对象的方法

        2.1 判断文件类型、获取文件信息的方法

        2.2 创建文件、删除文件的方法

        2.3 遍历文件夹的方法

        3.0 文件搜索与删除

        3.1 文件搜索

        3.2 文件删除


        1.0 File 文件概述

        在 Java 中,File 类是用于表示文件和目录路径的类,它提供了一组方法来操作文件系统中的文件和目录。File 类位于 java.io 包中,是 Java 中处理文件和目录的基本类之一。

        文件是非常重要的存储方式,在计算机硬盘中,即便断电,或者程序终止了,存储在硬盘文件中的数据也不会丢失。

        通过 File 类可以创建文件对象,从而获取文件信息(大小,文件名,修改时间),判断文件的类型,删除文件/文件夹等等。

        重点要注意的是:File 类只能文件本身进行操作,不能读写文件里面存储的数据。

        2.0 创建 File 类对象的方法

构造器:

        1)public File(String pathName):根据文件路径创建文件对象。

        2)public File(String parent,String child):根据父路径和子路径名字创建对象。

        3)public File(File parent,String child):根据父路径对应的文件对象和子路径名字创建文件对象。

代码如下:

import java.io.File;public class demo1 {public static void main(String[] args) {//第一种创建 File 类的方式:根据文件路径创建文件对象File file1 = new File("code_24_4_21/src/Text.text");//第二种创建 File 类的方式:根据父路径和子路径名字创建对象File file2 = new File("code_24_4_21.src/" ,"Text1.text");//第三种创建 File 类的方式:根据父路径对应的文件对象和子路径名字创建文件对象File parent = new File("code_24_4_21/src/");File file3 = new File(parent,"Text2.text");}
}

        需要注意的是:创建 File 对象是指代某一个具体的文件。即使文件本来是不存在,但是也可以创建该 File 文件对象。

        2.1 判断文件类型、获取文件信息的方法

代码如下:

import java.io.File;
import java.text.SimpleDateFormat;public class demo2 {public static void main(String[] args) {File file = new File("D:\\software\\code\\2023_java\\2023_java_code\\code_24_4_21\\src\\MyFile\\MyText.text");//1.0 判断当前文件是否存在boolean boo = file.exists();System.out.println(boo);//2.0 判断当前文件是否是文件boolean boo1 = file.isFile();System.out.println(boo1);//3.0 判断当前文件是否是文件夹boolean boo2 = file.isDirectory();System.out.println(boo2);//4.0 获取文件的名称String name = file.getName();System.out.println(name);//5.0 获取文件的大小,返回字节个数long size = file.length();System.out.println(size);//6.0 获取文件的最后修改时间long lastTime = file.lastModified();SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss");System.out.println(simpleDateFormat.format(lastTime));//7.0 获取创建文件对象时,使用的路径String getFilePath = file.getPath();System.out.println(getFilePath);//8.0 获取绝对路径String getAbsolutePath = file.getAbsolutePath();System.out.println(getAbsolutePath);}
}

运行结果:

        2.2 创建文件、删除文件的方法

        创建文件与创建文件对象是两回事:创建文件对象是指代某一个文件,不管文件是否存在,都可以指代;而创建文件是指在获取文件对象且该文件不存在来创建文件。

        1)public boolean createNewFile():创建一个新的文件(文件内容为空),创建成功返回 true ,反之。

代码如下:

import java.io.File;
import java.io.IOException;public class demo3 {public static void main(String[] args) throws IOException {File file = new File("D:\\software\\code\\2023_java\\2023_java_code\\code_24_4_21\\MyText01.text");boolean boo = file.createNewFile();System.out.println(boo);}
}

运行结果:

        2)public boolean mkdir():用于创建文件夹,注意:只能创建一级文件夹。

代码如下:

import java.io.File;public class demo4 {public static void main(String[] args) {File file = new File("D:\\software\\code\\2023_java\\2023_java_code\\code_24_4_21\\src\\DemoFile");boolean b = file.mkdir();System.out.println(b);}
}

运行结果:

        3)public boolean mkdirs():用创建文件夹,注意:可以创建多级文件夹。

代码如下:

import java.io.File;public class demo5 {public static void main(String[] args) {File file = new File("D:\\software\\code\\2023_java\\2023_java_code\\code_24_4_21\\src\\DemoFile\\Demo\\Dir\\");boolean b = file.mkdirs();System.out.println(b);}
}

运行结果:

        4)public boolean delete():删除文件、或者空文件,注意:不能删除非空文件夹。

代码如下:

import java.io.File;public class demo6 {public static void main(String[] args) {File file = new File("D:\\software\\code\\2023_java\\2023_java_code\\code_24_4_21\\MyText01.text");boolean b = file.delete();System.out.println(b);}
}

        这里尤其要注意的是:不能删除非空文件夹。

        2.3 遍历文件夹的方法

        1)public String[] list():获取当前目录下所有的“一级文件名称”到一个字符串数组中返回。

代码如下:

import java.io.File;public class demo7 {public static void main(String[] args) {File file = new File("D:\\software\\code\\2023_java\\2023_java_code");String[] l = file.list();for (String name : l){System.out.println(name);}}
}

        2)public File[] listFiles():获取当前目录下所有的“一级文件对象”到一个文件对象数组中返回。

代码如下:

import java.io.File;public class demo8 {public static void main(String[] args) {File file = new File("D:\\software\\code\\2023_java\\2023_java_code");File[] files = file.listFiles();for (File f:files){System.out.println(f.getAbsoluteFile());}}
}

运行结果:

使用 listFiles 方法时注意事项:

        1)当主调是文件,或者路径不存在时,返回 null 。

        2)当主调是空文件夹时,返回一个长度为 0 的数组。

        3)主调是一个文件夹,且里面有隐藏文件时,将里面所有文件和文件夹的路径放在 file 数组中返回,包含隐藏文件。

        4)当主调是一个文件夹,但是没有权限访问该文件夹时,返回 null 。

        3.0 文件搜索与删除

        3.1 文件搜索

        思想:从指定的路径开始搜索,每一次都获取到当目录下的所有一级文件对象,对文件数组进行遍历,若判断是文件,那么判断是否是目标文件,如果是文件,则返回该文件路径;若判断是文件夹,就要继续获取该文件夹下的一级文件,再来遍历当前新的文件数组,再遍历判断是否是目标文件。

        所以主要思想是遍历当前文件夹数组,判断是文件夹就要递归操作,判断是文件继续判断是否是目标文件。

代码如下:

import java.io.File;public class demo9 {//文件搜索public static void main(String[] args) {findFile("D:\\","WeChat.exe");}public static void findFile(String path,String name){File file = new File(path);//判断该文件是否是文件或者文件本来就不存在if ( file.isFile() || !file.exists()){return;}File[] files = file.listFiles();if (files == null){return;}for (int i = 0; i < files.length; i++) {File temp = files[i];if (temp.isFile()){if (temp.getName().equals(name)){System.out.println("找到目标文件了 --> " + temp.getAbsolutePath());return;}}else {findFile(temp.getAbsolutePath(),name);}}}}

运行结果:

        3.2 文件删除

        之前介绍的 delete() 方法只能删除文件还有空文件夹,但是对于非空的文件夹是不能删除。那么如果非要删除文件夹该怎么办呢?

        删除文件夹思路:将文件夹里面的所有文件先删除掉,对于文件夹里面的文件夹继续获取下一级文件对象数组,同样的想法,继续先将文件先删除掉,对于是文件夹对象了,那么继续获取下一级文件对象数组。

        所以,该思路跟文件查询操作的思路差不多,也是用到了遍历数组,递归操作。

import java.io.File;public class demo10 {public static void main(String[] args) {deleteFile("D:\\software\\ademo");}public static void deleteFile(String dir){if (dir == null){return;}//需要删除的文件夹File file = new File(dir);if (file.isFile() || !file.exists()){return;}File[] files = file.listFiles();if (files == null){return;}for (int i = 0; i < files.length; i++) {File tempFile = files[i];if (tempFile.isFile()){tempFile.delete();}else {deleteFile(tempFile.getAbsolutePath());}}file.delete();}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/1318.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

OSPF面试题收集

第一章:基础理论部分 基础部分面试官主要是问一些简单得原理,口头描述的东西。不会涉及到报文的参数属性等。 OSPF是什么 定义也就是链路状态协议和距离矢量协议的区别区别。 开放式最短路径优先协议 路由是以自己为根,根据数据库计算去往所有树枝节点的最佳路径放进自己…

WebSocket 快速入门 - springboo聊天功能

目录 一、概述 1、HTTP&#xff08;超文本传输协议&#xff09; 2、轮询和长轮询 3、WebSocket 二、WebSocket快速使用 1、基于Java注解实现WebSocket服务器端 2、JS前端测试 三、WebSocket进阶使用 1、如何获取当前用户信息 2、 后端聊天功能实现 一、概述 HTTP…

PVE grub resue错误修复 lvmid BUG

服务器断电后启动不起来&#xff0c;显示grub resue 找了半天没有找到修复方法。看官方文档有一处Recovering from grub “disk not found” error when booting from LVM 极为类似。https://pve.proxmox.com/wiki/Recover_From_Grub_Failure 下面是处理过程。 使用PVE 6.4启…

Leetcode算法训练日记 | day33

专题九 贪心算法 一、跳跃游戏 1.题目 Leetcode&#xff1a;第 55 题 给你一个非负整数数组 nums &#xff0c;你最初位于数组的 第一个下标 。数组中的每个元素代表你在该位置可以跳跃的最大长度。 判断你是否能够到达最后一个下标&#xff0c;如果可以&#xff0c;返回 …

机器学习(二)之监督学习

前言&#xff1a; 上一节大概讲解了几种学习方式&#xff0c;下面几张就具体来讲讲监督学习的几种算法。 以下示例中和都是权重的意思&#xff01;&#xff01;&#xff01; 注&#xff1a;本文如有错误之处&#xff0c;还请读者指出&#xff0c;欢迎评论区探讨&#xff01; 1…

MATLAB实现图片栅格化

MATLAB实现图片栅格化 1.读取图片&#xff1a;首先&#xff0c;你需要使用imread函数读取要栅格化的图片。 2.设置栅格大小&#xff1a;确定你希望将图片划分成的栅格大小&#xff0c;即每个栅格的宽度和高度。 3.计算栅格数量&#xff1a;根据图片的总尺寸和栅格大小&#…

搜索+剪枝,LeetCode 216. 组合总和 III

目录 一、题目 1、题目描述 2、接口描述 python3 cpp 3、原题链接 二、解题报告 1、思路分析 2、复杂度 3、代码详解 python3 cpp 一、题目 1、题目描述 找出所有相加之和为 n 的 k 个数的组合&#xff0c;且满足下列条件&#xff1a; 只使用数字1到9每个数字 最多…

Compose 布局

文章目录 Compose 布局ColumnColumn属性使用 RowRow属性使用 BoxBox属性使用 ConstraintLayoutLazyColumnLazyColumn属性使用使用多类型使用粘性标题回到顶部 LazyRowLazyRow属性使用 LazyVerticalGridLazyVerticalGrid属性使用 Compose 布局 Column Compose中的”垂直线性布…

F-logic DataCube3 SQL注入漏洞复现(CVE-2024-31750)

0x01 产品简介 F-logic DataCube3是一款用于光伏发电系统的紧凑型终端测量系统。 0x02 漏洞概述 F-logic DataCube3 /admin/pr_monitor/getting_index_data.php 接口处存在SQL注入漏洞,未经身份验证的攻击者可通过该漏洞获取数据库敏感信息,深入利用可控制整个web服务器。 …

计算机图形学:直线生成算法—DDA

DDA&#xff08;Digital Differential Analyzer&#xff0c;数字差分分析器&#xff09;算法是一种基本的直线生成算法&#xff0c;通常用于计算机图形学中。它通过将直线划分为若干个等间隔的小线段&#xff0c;然后在每个小线段中选择一个像素点进行绘制&#xff0c;从而近似…

R-Tree:空间索引技术原理及实现详解

R-Tree&#xff1a;空间索引技术原理及实现详解 一、引言 在空间数据库中&#xff0c;如何高效地查询和处理空间数据一直是研究的热点。R-Tree作为一种重要的空间索引结构&#xff0c;在地理信息系统&#xff08;GIS&#xff09;、空间数据库管理系统等领域得到了广泛应用。本…

三十二章、Cesium从入门到精通;

一、打造第一个Cesium程序&#xff1b; 1、基础概念&#xff1b; 父子组件之间可以传递数据&#xff1a;props、回传事件&#xff1b; 使用Redux使用场景&#xff1a;兄弟&#xff1b; 2、代码样例&#xff1b; 11111111 二、Cesium基础设置&#xff1b; 三、讲解viewer…

产品原型图概念

产品原型图概念 产品原型图作用 如下图&#xff1a; 产品原型图的三种分类 线框图 通过【线段色块文字】描述产品页面。优点&#xff1a;制作快速。 缺点&#xff1a;传递信息容易遗漏。 应用&#xff1a;早期方案讨论&#xff0c;需要快速输出的场景&#xff0c;团队配合…

Java算法必备之快读

背景: 在一些算法题中,由于数据量过大,可能会出现卡输入输出时间的问题 原理: 在Java中,输入通常是使用Scanner,输出使用System.out,先说输入 Scanner in new Scanner(System.in);慢的原因有两方面: System.in在读取的时候是字节流进行读取,是一个字节一个字节读取的,在读取…

【工作杂记】groupBy排序-操作word

1.stream 流 groupBy 排序 stream流groupBy默认使用的HashMap&#xff0c;无序的&#xff0c;想要实现有序&#xff0c;需要手动指定接收的map类型 例子&#xff1a; Map<Date, List<OrderVo>> dataMap voList.stream().sorted(Comparator.comparing(OrderVo::ge…

华为OD-C卷-执行任务赚积分[100分]C++ 100%

题目描述 现有N个任务需要处理,同一时间只能处理一个任务,处理每个任务所需要的时间固定为1。 每个任务都有最晚处理时间限制和积分值,在最晚处理时间点之前处理完成任务才可获得对应的积分奖励。 可用于处理任务的时间有限,请问在有限的时间内,可获得的最多积分。 输…

Learn ComputeShader 01 First Computer Shader

使用Unity版本&#xff1a;2019.4.12f1 整体流程&#xff1a; 1添加一个quad object并添加一个无光照材质 2.相机投影模式设置为正交 3.调整quad使其完全显示在相机内 4.创建脚本并且使用计算着色器覆盖quad的纹理 5.创建一个compute shader 前三步完成以后结果应该是这…

网络基础先导

前言&#xff1a;最好在牢固前面几大件&#xff08;编程语言、数据结构、操作系统&#xff09;&#xff0c;并且您有一个服务器的基础上&#xff08;我使用的是腾讯云中配置最低的服务器&#xff09;再来学习本系列的网络知识。 1.网络发展简要 下面就是简单提及一些概念而已&…

多线程(64)如何设计一个高性能的订单处理系统

设计一个高性能的订单处理系统需要考虑多个方面&#xff0c;包括但不限于系统架构、数据一致性、可伸缩性、容错性以及性能优化。以下是设计这样一个系统的一些关键考虑因素和实现策略。 系统架构 微服务架构&#xff1a;将订单系统分解成独立的微服务&#xff0c;例如订单创建…

二叉树之AVL树

文章目录 1. AVL树的概念&#xff08;logN)1.1背景1.2规则 2.AVL树节点的定义3.AVL树的插入4. AVL树的旋转(重点&#xff09;4.1 新节点插入较高的右子树的右侧&#xff1a;左单璇&#xff1b;4.2 新节点插入较高左子树的左侧&#xff1a;右单璇&#xff1b;4.3&#xff08;双旋…