JavaEE 文件操作IO

文件操作&IO

文章目录

  • 文件操作&IO
    • 1. 认识文件
    • 2. 文件操作
      • 2.1 File 类
      • 2.2 文件读写
        • 2.2.1 FileInputStream
        • 2.2.2 FileOutputStream
        • 2.2.3 FileReader
        • 2.2.4 FileWriter
        • 2.2.5 Scanner读取文件
      • 3. 案例练习
        • 3.1 案例一
        • 3.2 案例二
        • 3.3 案例三

在进行文件操作之前,我们先简单了解一些文件的基本概念

1. 认识文件

对于计算机来说,文件是一个相对广义的概念,在硬盘上,我们可以将存储着一定数据的独立个体抽象为文件,同时,文件除了有数据内容之外,还有一部分信息,例如文件名、文件类型、文件大小等并不作为文件的数据而存在,我们把这部分信息称为文件的元信息。

在这里插入图片描述

同时,随着文件数量的增加,我们也需要对文件进行一定的组织管理, 对此,我们使用层级结构来对文件进行组织,也就是我们数据结构学习过的树型结构

在这里插入图片描述

同时也诞生了一种用来存储管理文件信息的特殊文件–文件夹(folder) /目录(directory)

在这里插入图片描述

:这里提到的树不是“二叉树”,而是N叉树,每一个普通文件(非目录)就是叶子节点,一个目录文件中又可以有很多的子节点

在这里插入图片描述

在操作系统中,我们通过路径来定位我们的文件,并将路径分为以下两种:

  • 绝对路径(absolute path): 从树型结构的角度来看,树种的每个节点都可以被一条从根开始一直到目标文件节点的结束路径所描述,而这种描述方式就被称为绝对路径。

    在这里插入图片描述

  • 相对路径(relative path): 除了可以从根开始进行路径的描述,我们可以从任意节点出发,进行路径的描述,而这种描述方式就被称为相对路径,相当于当前所在节点的一条路径。

    在这里插入图片描述

一般我们会将文件分为两类:文本文件二进制文件

  • 文本文件:指代保存被字符集编码的文本

  • 二进制文件:指代按照标志格式保存的非本字符集编码过的文件

对于我们来说,如何判定一个文件是文本文件还是二进制文件?

这里可以通过记事本来打开这个文件,打开后看到的如果是正常内容不是乱码就说明是文本文件,而如果是乱码就证明是二进制文件

了解了以上内容之后,我们就可以来进行文件操作了~

2. 文件操作

2.1 File 类

Java中通过java.io.File 类来对一个文件(包括目录)进行抽象的描述。注意,有File对象并不代表真实存在该文件

属性

修饰符及类型属性说明
static StringpathSeparator依赖于系统的路径分隔符,String 类型的表示
static charpathSeparator依赖于系统的路径分隔符,char类型的表示

构造方法

签名说明
File(File parent, String child)根据父目录 + 孩子文件路径,创建⼀个新的 File 实例
File(String pathname)根据文件路径创建⼀个新的 File 实例,路径可以是绝 对路径或者相对路径
File(String parent, String child)根据父目录 + 孩子文件路径,创建⼀个新的 File 实 例,父目录用路径表示

方法

修饰符及返回值类型方法签名说明
StringgetParent()返回File对象的父目录文件路径
StringgetName()返回File对象的纯文件名称
StringgetPath()返回File对象的文件路径
StringgetAbsolutePath()返回File对象的绝对路径
StringgetCanonicalPath()返回File对象的修饰过的绝对路径
booleanexists()判断File对象描述的文件是否真实存在
booleanisDirectory()判断File对象代表的文件是否是一个目录
booleanisFile()判断File对象代表的文件是否是一个普通文件
booleancreateNewFile()根据File对象,自动创建一个空文件。成功创建后返回true
booleandelete()根据File对象,删除该文件。成功删除后返回true
voiddeleteOnExit()根据File对象,标注文件将被删除,删除动作会到JVM运行结束时才会结束
String[]list()返回File对象代表的目录下的所有文件名
File[]listFiles()返回File对象代表的目录下的所有文件,以File对象表示
booleanmkdir()创建File对象代表的目录
booleanmkdirs()创建File对象代表的目录,如果必要,会创建中间目录
booleanrenameTo(Filedest)进行文件改名,也可以视为我们平时的剪切、粘贴操作
booleancanRead()判断用户是否对文件有可读权限
booleancanWrite()判断用户是否对文件有可写权限

创建文件

package demo1;import java.io.File;
import java.io.IOException;
import java.util.Arrays;public class Test1 {public static void main(String[] args) throws IOException {File file = new File("./test.txt");System.out.println(file.exists()); // 判断文件是否存在System.out.println(file.isFile()); // 判断是否为文件类型System.out.println(file.isDirectory()); // 判断是否为目录System.out.println(file.createNewFile()); // 创建文件 文件不存在时自动创建并返回true}
}

在这里插入图片描述

删除文件

package demo1;import java.io.File;
import java.io.IOException;
import java.util.Arrays;public class Test1 {public static void main(String[] args) throws IOException {File file = new File("./test.txt");boolean ret = file.delete(); // 删除文件System.out.println(ret);/*file.deleteOnExit(); // 线程结束后再删除文件*/}
}

在这里插入图片描述

创建目录

package demo1;import java.io.File;public class Test3 {public static void main(String[] args) {File f = new File("./aaa/bbb/ccc");boolean ret = f.mkdirs(); // 创建目录System.out.println(ret);}
}

在这里插入图片描述

2.2 文件读写

对于文件,我们一般有以下两种读取文件的文件流方式:

  1. 字节流: 每次读写的最小单位是一个字节

    代表类:InputStream 输入(读取文件); OutputStream 输出(写入文件);

  2. 字符流: 每次读写的最小单位是一个字符(一个字符可能有多个字节构成,同时字符流可以内部处理字符编码);

    代表类:Reader 输入; Writer 输出;

2.2.1 FileInputStream

这里我们引入FileInputStream 而不是前面提到的InputStream, 原因是InputStream只是一个抽象类,要使用还需要具体的实现类,在这里我们只需要从文件中进行读取,所有使用FileInputStream(字节流)

构造方法

签名说明
FileInputStream(File file)利用File构造文件输入流
FileInputStream(String name)利用文件路径构造文件输入流

代码示例

package demo2;import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.InputStream;public class Test1 {public static void main(String[] args) throws IOException {try (InputStream inputStream = new FileInputStream("./test.txt")) {// 字节流读文件// 不知道文件有多少字节,用while来完成while(true) {byte[] buffer = new byte[1024]; // 缓冲区int n = inputStream.read(buffer); // 返回值为读取的字节数,并将读取的值存放到缓冲区中if (n == -1) {break; // n = -1 表示字节已全部读取完毕}String s = new String(buffer, 0, n);System.out.println(s);}}catch (IOException e) {throw new RuntimeException(e);}}
}

在这里插入图片描述

:我们要认识到,读文件就是把硬盘数据读取到内存中,所以我们以内存为对象,使用”input“将数据从硬盘中输入给自己,反之,写文件用"output"就是将内存中的数据输出给硬盘对硬盘上的数据进行修改

2.2.2 FileOutputStream

OutputStream 同样只是一个抽象类,要使用还需要具体的实现类,这里我们使用FileOutputStream 来完成写入文件操作(字节流)

构造方法

签名说明
FileOutputStream(File file)利用File构造文件输出流
FileOutputStream(String name, boolean append)利用文件路径构造文件输出流, 传入参数true代表当前为追加模式

代码示例

package demo2;import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStream;public class Test2 {public static void main(String[] args) {// 使用OutputStream写文件 true为追加模式try(OutputStream outputStream = new FileOutputStream("test.txt", true)) {byte[] buffer = new byte[] {97,98,99,100,101};outputStream.write(buffer);} catch (IOException e) {throw new RuntimeException(e);}}
}

在这里插入图片描述

:在构造方法中传入参数true代表当前为追加模式

2.2.3 FileReader

Reader是一个抽象类,要使用还需要具体的实现类,这里我们使用FileReader来完成读取文件操作(字节流)

代码示例

package demo2;import java.io.FileReader;
import java.io.IOException;
import java.io.Reader;public class Test3 {public static void main(String[] args) {// 字符流读文件try (Reader reader = new FileReader("test.txt")) {while (true) {char[] buffer = new char[1024]; // 此处以char为单位进行操作int n = reader.read(buffer);if (n == -1) {break;}String s = new String(buffer, 0, n);System.out.println(s);}} catch (IOException e) {throw new RuntimeException(e);}}
}

在这里插入图片描述

2.2.4 FileWriter

Writer是一个抽象类,要使用还需要具体的实现类,这里我们使用FileWriter来完成写入文件操作(字节流)

代码示例

package demo2;import java.io.FileWriter;
import java.io.IOException;
import java.io.Writer;public class Test4 {public static void main(String[] args) {// 使用字符流修改文件try (Writer writer = new FileWriter("test.txt", true)) {String s = "\n你也好";writer.write(s);} catch (IOException e) {throw new RuntimeException(e);}}
}

在这里插入图片描述

2.2.5 Scanner读取文件

Scanner 也可以辅助我们读取文件

代码示例

package demo2;import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.util.Scanner;public class Test5 {public static void main(String[] args) {try (InputStream inputStream = new FileInputStream("test.txt")) {Scanner scanner = new Scanner(inputStream);while (scanner.hasNext()) {String s = scanner.next(); // next无法读取空格System.out.println(s);}} catch (IOException e) {throw new RuntimeException(e);}}
}

在这里插入图片描述

3. 案例练习

3.1 案例一

扫描指定目录,并找到名称中包含指定字符的所有普通文件(不包含目录)

代码示例

package demo3;import java.io.File;
import java.util.Scanner;public class Test1 {public static void main(String[] args) {// 1. 输入必要的信息Scanner scanner = new Scanner(System.in);System.out.println("请输入要搜索的文件名:");String fileName = scanner.next();System.out.println("请输入要搜索的目录:");String rootPath = scanner.next();File rootFile = new File(rootPath);if (!rootFile.isDirectory()) {System.out.println("输入的路径有误");return;}// 2. 有了要搜索的路径之后,就可以按照 递归 的方式来搜索scanDir(rootFile, fileName);}private static void scanDir(File rootFile, String fileName) {// 1. 把当前目录中的文件和子目录都列出来File[] files = rootFile.listFiles();if (files == null) {// 空的目录,直接返回即可return;}// 2. 遍历上述files,判断每一个file是目录还是文件for (File f : files) {System.out.println("当前遍历到:" + f.getAbsolutePath());if (f.isFile()) {// 普通文件,判定文件名是否是搜索的文件if (fileName.equals(f.getName())) {System.out.println("找到了符合要求的文件!" + f.getAbsolutePath());}}else if (f.isDirectory()) {// 目录文件,需要进一步递归scanDir(f, fileName);}}}
}

在这里插入图片描述

在这里插入图片描述

3.2 案例二

对普通文件进行复制

代码示例

package demo3;import java.io.*;
import java.util.Scanner;public class Test2 {public static void main(String[] args) {Scanner scanner = new Scanner(System.in);System.out.println("请输入要复制的源文件:");String srcPath = scanner.next();System.out.println("请输入要复制的目标文件:");String destPath = scanner.next();// 合法性判定// 1 srcPath 对应的文件是否存在File srcFile = new File(srcPath);if (!srcFile.isFile()) {System.out.println("源文件路径有误!");return;}// 2 destPath 不要求对应的文件存在,但目录得存在File destFile = new File(destPath);if (!destFile.getParentFile().isDirectory()) {System.out.println("目标路径有误!");return;}// 复制操作try (InputStream inputStream = new FileInputStream(srcFile);OutputStream outputStream = new FileOutputStream(destFile)) {while (true) {byte[] buffer = new byte[1024];int n = inputStream.read(buffer);if (n == -1) {break;}// 把读到的内容写入到 outputStream 中outputStream.write(buffer, 0, n);}} catch (IOException e) {throw new RuntimeException(e);}}
}

在这里插入图片描述

在这里插入图片描述

3.3 案例三

扫描指定目录,并找到内容中包含指定字符的所有普通文件

代码示例

package demo3;import java.io.*;
import java.util.Scanner;public class Test3 {public static void main(String[] args) {Scanner scanner = new Scanner(System.in);System.out.println("请输入要搜索的路径:"); // 从哪个目录开始搜索String rootPath = scanner.next();System.out.println("请输入要查询的词:");String word = scanner.next();File rootFile = new File(rootPath);if (!rootFile.isDirectory()) {System.out.println("输入的要搜索的路径不正确!");return;}scanDir(rootFile, word);}private static void scanDir(File rootFile, String word) {File[] files = rootFile.listFiles();if (files == null) {return;}for (File f : files) {System.out.println("当前遍历到: " + f.getAbsolutePath());if (f.isFile()) {// 在文件内容中搜索searchInFile(f, word);}else if (f.isDirectory()) {scanDir(f, word);}}}private static void searchInFile(File f, String word) {// 通过这个方法在文件内部进行搜索// 1. 把文件内容都读取出来try (InputStream inputStream = new FileInputStream(f)) {StringBuilder stringBuilder = new StringBuilder();while (true) {byte[] buffer = new byte[1024];int n = inputStream.read(buffer);if (n == -1) {break;}// 此处只是读取出文件的一部分,需要把文件内容整体拼接在一起String s = new String(buffer, 0, n);stringBuilder.append(s);}if (stringBuilder.indexOf(word) == -1) {// 没有找到要返回return;}System.out.println("找到了! " + word + "存在于" + f.getAbsolutePath());} catch (IOException e) {throw new RuntimeException(e);}}
}

在这里插入图片描述
在这里插入图片描述

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

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

相关文章

数据操作——缺失值处理

缺失值处理 缺失值的处理思路 如果想探究如何处理无效值, 首先要知道无效值从哪来, 从而分析可能产生的无效值有哪些类型, 在分别去看如何处理无效值 什么是缺失值 一个值本身的含义是这个值不存在则称之为缺失值, 也就是说这个值本身代表着缺失, 或者这个值本身无意义, 比如…

GPT应用程序的开发注意事项

GPT应用程序的开发语言可以选择多种语言,主要取决于您的偏好、团队的技能以及应用程序的具体需求。以下是一些常见的用于GPT应用程序开发的编程语言,希望对大家有所帮助。北京木奇移动技术有限公司,专业的软件外包开发公司,欢迎交…

项目管理流程

优质博文 IT-BLOG-CN 一、简介 项目是为提供某项独特产品【独特指:创造出与以往不同或者多个方面与以往有所区别产品或服务,所以日复一日重复的工作就不属于项目】、服务或成果所做的临时性【临时性指:项目有明确的开始时间和明确的结束时间,不会无限期…

【Web前端开发基础】CSS的盒子模型

CSS的盒子模型 一、学习目标 能够认识不同选择器的优先级公式能够进行CSS权重叠加计算,分析并解决CSS 冲突问题能够认识盒子模型的组成部分能够掌握盒子模型的边框、内边距、外边距的作用及简写形式能够计算盒子的实际大小能够了解外边距折叠现象,并知…

Linux用户空间和内核空间所有15种内存分配方法

在Linux操作系统中,内存管理是一个关键的系统功能。用户空间和内核空间分别使用不同的函数来申请内存。以下是用户空间和内核空间内存申请函数的详细列表: Linux用户空间内存申请函数 1. malloc() 函数: void* malloc(size_t size); 用于…

在IDEA中使用快捷键让XML注释更加规范

Setting -> Editor -> Code Style -> XML 取消勾选 Line comment at first column 这样我们在使用ctrl / 快速注释时,就可以让注释符号紧贴注释内容,不出现空格。

如何唯一标识一个进程

如何唯一标识一个进程 进程ID (PID): 每个运行中的进程都有一个全局唯一的整数标识符,称为进程ID(Process ID)。PID由内核分配,并在整个系统范围内保持唯一。 在shell中输入echo $$来查看当前shell的进程ID&#xf…

ip_vs 的管理以及 keepalived + lvs 案例

ip_vs 的管理 ipvsadm 与 keepalived for lvs ipvsadm 命令及参数介绍 部署和配置LVS服务会经常用到一些命令,如ipvsadm,可以使用“ipvsadm -help”命令查看使用帮助。 ipvsadm 命令的常用参数及其说明如下: # 添加虚拟服务器# 语法&#x…

PLC从HTTP服务端获取JSON文件,解析数据到寄存器

智能网关IGT-DSER集成了多种PLC协议,方便实现各种PLC与HTTP服务端之间通讯。通过网关的参数配置软件绑定JSON文件的字段与PLC寄存器地址,配置URL,即可采用POST命令,将JSON文件提交给HTTP的服务端; 服务端有返回的JSON&…

【JavaEE】认识网络的工作原理

作者主页:paper jie_博客 本文作者:大家好,我是paper jie,感谢你阅读本文,欢迎一建三连哦。 本文于《JavaEE》专栏,本专栏是针对于大学生,编程小白精心打造的。笔者用重金(时间和精力)打造&…

66 C++对象模型探索。C++编译器在什么时候给我们创建默认的构造函数?

一 前提,关于C编译器给我们生成 默认构造函数 的错误认知 传统知识认为:如果在一个类中,我们没有定义任何的构造函数,那么编译器会为我们隐式自动定义一个默认的构造函数,我们称这种构造函数为 "合成的默认构造函…

德思特方案|EMI兼容测试方案——匹配不同测试标准,准确高效!

方案背景 近场测试非常适合产品开发阶段辐射发射的EMI预兼容测试。在EMC测试中,进行辐射发射测试时,通常天线离被测物EUT很远,进行的都是远场测量。标准的远场辐射发射测试,可以准确定量的告诉我们被测件是否符合相应的EMC/EMI标…

SpringCloudConfig+SpringCloudBus+Actuator+Git实现Eureka关键配置属性热更新(全程不重启服务)

文章目录 前言1.痛点2.解决方案3.具体实现3.1搭建热配置服务3.2编写配置文件3.3搭建版本控制仓库3.4Eureka-Client引入以下依赖3.5Eureka-Client微服务编写以下配置bootstrap.yml提前加载3.6分别编写测试Controller3.7测试效果3.8下线场景压测 4.SpringCloudBus优化 前言 在上…

imgaug库图像增强指南(32):塑造【雪景】效果的视觉魔法

引言 在深度学习和计算机视觉的世界里,数据是模型训练的基石,其质量与数量直接影响着模型的性能。然而,获取大量高质量的标注数据往往需要耗费大量的时间和资源。正因如此,数据增强技术应运而生,成为了解决这一问题的…

Django(九)

1. 用户登录-Cookie和Session 什么是cookie和session? 发送HTTP请求或者HTTPS请求(无状态&短连接) http://127.0.0.1:8000/admin/list/ https://127.0.0.1:8000/admin/list/http无状态短连接:一次请求响应之后断开连接,再发请求重新连…

PCB导线阻抗概念

1. 计算公式 https://baijiahao.baidu.com/s?id1750340479004609055&wfrspider&forpc Z087/SQRT(εr1.41)ln[(5.98h)/(0.8wt)] 常规来说阻抗与介电常数成反比,与介质层厚度成正比,与线宽成反比,与铜厚成反比。 Z0:印刷导线的特性阻抗 εr:绝缘…

RK3568笔记十:Zlmediakit交叉编译

若该文为原创文章,转载请注明原文出处。 编译Zlmediakit的主要目的是想实现在RK3568拉取多路RTPS流,并通过MPP硬解码,DRM显示出来。为了实现拉取多路流选择了Zlmediakit,使用FFMEPG也可以,在RV1126上已经验证了可行性。 一、环境…

PyTorch深度学习实战(31)——生成对抗网络(Generative Adversarial Network, GAN)

PyTorch深度学习实战(31)——生成对抗网络 0. 前言1. GAN2. GAN 模型分析3. 利用 GAN 模型生成手写数字小结系列链接 0. 前言 生成对抗网络 (Generative Adversarial Networks, GAN) 是一种由两个相互竞争的神经网络组成的深度学习模型,它由…

Flask框架小程序后端分离开发学习笔记《3》客户端向服务器端发送请求

Flask框架小程序后端分离开发学习笔记《3》客户端向服务器端发送请求 Flask是使用python的后端,由于小程序需要后端开发,遂学习一下后端开发。 一、为什么请求数据需要先编码 #构造一个HTTP请求 http_request GET / HTTP/1.1\r\nhost:{}\r\n\r\n.for…

大语言模型系列-ELMo

文章目录 前言一、ELMo的网络结构和流程二、ELMo的创新点总结 前言 在前文大语言模型系列-word2vec已经提到word2vec的缺点: 为每个词汇表中每个分词静态生成一个对应的词向量表示,没有考虑到语境,因此无法无法处理多义词 ps:先…