Java对文件进行基本操作案例讲解

网友投稿 283 2022-12-29

Java对文件进行基本操作案例讲解

File文件类

java.io.File是文件和目录的重要类(JDK6及以前是唯一)

目录也使用File类进行表示

File类与操作系统无关,但会受到操作系统的权限限制

常用方法

createNewFile , delete , exists , getAbsolutePath , getName , getParent , getPath

isDirectory , isFile , length , listFiles , mkdir , mkdirs

File不涉及到具体的文件内容、只会涉及属性

public static void main(String[] args) {

// 创建目录

File directory = new File("D:/temp");

boolean directoryDoesNotExists = ! directory.exists();

if (directoryDoesNotExists) {

// mkdir是创建单级目录

// mkdirs是连续创建多级目录

directory.mkdirs();

}

// 创建文件

File file = new File("D:/temp/test.txt");

boolean fileDoesNotExsits = ! file.exists();

if (fileDoesNotExsits) {

try {

file.createNewFile();

} catch (IOException e) {

e.printStackTrace();

}

}

// 遍历directory下的所有文件消息

File[] files = directory.listFiles();

for (File file1 : files) {

System.out.println(file1.getPath());

}

}

运行结果:

D:\temp\test.txt

Java NIO

Java 7提出的NIO包,提出新的文件系统类Path , Files , DirectoryStream , FileVisitor , FileSystem是对java.io.File的有益补充文件复制和移动文件相对路径递归遍历目录递归删除目录

Path类

public static void main(String[] args) {

// Path和java.io.File基本类似

Path path = FileSystems.getDefault().getPath("D:/temp", "abc.txt");

// D:/ 返回1 D:/temp 返回2

System.out.println(path.getNameCount());

// 用File的toPath()方法获取Path对象

File file = new File("D:/temp/abc.txt");

Path path1 = file.toPath();

System.out.println(path.compareTo(path1)); // 结果为0 说明两个path相等

// 获取Path方法三

Path path3 = Paths.get("D:/temp", "abc.txt");

// 判断文件是否可读

System.out.println("文件是否可以读取: " + Files.isReadable(path));

}

Files类

public static void main(String[] args) {

// 移动文件

moveFile();

// 访问文件属性

fileAttributes();

// 创建目录

createDirectory();

}

private static void createDirectory() {

Path path = Paths.get("D:/temp/test");

try {

// 创建文件夹

if (Files.notExists(path)) {

Files.createDirectory(path);

} else {

System.out.println("文件夹创建失http://败");

}

Path path2 = path.resolve("a.java");

Path path3 = path.resolve("b.java");

Path path4 = path.resolve("c.txt");

Path path5 = path.resolve("d.jpg");

Files.createFile(path2);

Files.createFile(path3);

Files.createFile(path4);

Files.createFile(path5);

// 不带条件的遍历输出

DirectoryStream listDirectory = Files.newDirectoryStream(path);

for (Path path1 : listDirectory) {

System.out.println(path1.getFileName());

}

// 创建一个带有过滤器,过滤文件名以java txt结尾的文件

DirectoryStream pathsFilter = Files.newDirectoryStream(path, "*.{java,txt}");

for (Path item : pathsFilter) {

System.out.println(item.getFileName());

}

} catch (Exception e) {

e.printStackTrace();

}

}

@SuppressWarnings("all")

private static void fileAttributes() {

Path path = Paths.get("D:/temp");

// 判断是否是目录

System.out.println(Files.isDirectory(path, LinkOption.NOFOLLOW_LINKS));

try {

// 获取文件的基础属性

BasicFileAttributes attributes = Files.readAttributes(path, BasicFileAttributes.class);

// 判断是否是目录

System.out.println(attributes.isDirectory());

// 获取文件最后修改时间

System.out.println(new Date(attributes.lastModifiedTime().toMillis()).toLocaleString());

} catch (Exception e) {

e.printStackTrace();

}

}

private static void moveFile() {

Path from = Paths.get("D:/temp", "text.txt");

// 将文件移动到D:/temp/test/text.txt, 如果目标文件以存在则替换

Path to = from.getParent().resolve("test/text.txt");

try {

// 文件大小bytes

System.out.println(Files.size(from));

// 调用文件移动方法,如果目标文件已存在则替换

Files.move(from, to, StandardCopyOption.REPLACE_EXISTING);

} catch (Exception e) {

emWjRuhp e.printStackTrace();

}

}

递归遍历查找指定文件

public class Demo2 {

public static void main(String[] args) {

// 查找以.jpg结尾的

String ext = "*.jpg";

Path fileTree = Paths.get("D:/temp/");

Search search = new Search(ext);

EnumSet options = EnumSet.of(FileVisitOption.FOLLOW_LINKS);

try {

Files.walkFileTree(fileTree, options, Integer.MAX_VALUE, search);

} catch (IOException e) {

e.printStackTrace();

}

}

}

class Search implements FileVisitor {

private PathMatcher matcher;

public Search(String ext) {

this.matcher = FileSystems.getDefault().getPathMatcher("glob:" + ext);

}

public void judgeFile(Path file) throws IOException {

Path name = file.getFileName();

if (name != null && matcher.matches(name)) {

// 文件名匹配

System.out.println("匹配的文件名: " + name);

}

}

// 访问目录前调用

@Override

public FileVisitResult preVisitDirectory(Object dir, BasicFileAttributes attrs) throws IOException {

return FileVisitResult.CONTINUE;

}

// 访问文件时调用

@Override

public FileVisitResult visitFile(Object file, BasicFileAttributes attrs) throws IOException {

judgeFile((Path) file);

return FileVisitResult.CONTINUE;

}

// 访问文件失败后调用

@Override

public FileVisitResult visitFileFailed(Object file, IOException exc) throws IOException {

return FileVisitResult.CONTINUE;

}

// 访问一个目录后调用

@Override

public FileVisitResult postVisitDirectory(Object dir, IOException exc) throws IOException {

System.out.println("postVisit: " + (Path) dir);

return FileVisitResult.CONTINUE;

}

}

运行结果:

匹配的文件名: d.jpg

postVisit: D:\temp\test

postVisit: D:\temp

Java的IO包

Java读写文件,只能以数据流的形式进行读写java.io包中节点类:直接对文件进行读写包装类:1、转换类:字节 / 字符 / 数据类型的转化类 。2、装饰类:装饰节点类。

节点类

直接操作文件类InputStream,OutStream(字节) FileInputStream , FileOutputStream Reader , Writer(字符) FileReader , FileWriter

转换类

从字符到字节之间的转化InputStreamReader: 文件读取时字节,转化为Java能理解的字符OutputStreamWriter: Java将字符转化为字节输入到文件中

装饰类

DataInputStream , DataOutputStream :封装数据流BufferedInputStream ,BufferOutputStream:缓存字节流BufferedReader , BufferedWriter:缓存字符流

文本文件的读写

写操作

public static void main(String[] args) {

writeFile();

}

public static void writeFile(){

try (BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(new FileOutputStream("D:/temp/demo3.txt")))) {

bw.write("hello world");

bw.newLine();

bw.write("Java Home");

bw.newLine();

} catch (Exception e) {

e.printStackTrace();

}

}

Demo3.txt文件内容

hello world

Java Home

读操作

public static void main(String[] args) {

readerFile();

}

private static void readerFile() {

String line = "";

try (BufferedReader br = new BufferedReader(new InputStreamReader(new FileInputStream("D:/temp/demo3.txt")))) {

while ((line = br.readLine()) != null) {

System.out.println(line);

}

} catch (Exception e) {

e.printStackTrace();

}

}

运行结果:

hello world

Java Home

二进制文件读写java

public static void main(String[] args) {

writeFile();

}

private static void writeFile() {

try (DataOutputStream dos = new DataOutputStream(new BufferedOutputStream(new FileOutputStream("D:/temp/test.dat")))) {

dos.writeUTF("hello");

dos.writeUTF("hello world is test bytes");

dos.writeInt(20);

dos.writeUTF("world");

} catch (Exception e) {

e.printStackTrace();

}

}

文件内容

hellohello world is test bytes world

读操作

public static void main(String[] args) {

readFile();

}

private static void readFile() {

try (DataInputStream in = new DataInputStream(new BufferedInputStream(new FileInputStream("D:/temp/test.dat")))) {

System.out.println(in.readUTF() + in.readUTF() + in.readInt() + in.readUTF());

} catch (Exception e) {

e.printStackTrace();

}

}

运行结果:

hellohello world is test bytes20world

ZIP文件的读写

zip文件操作类:java.util.zip包中

java.io.InputStream , java.io.OutputStream的子类

ZipInputStream , ZipOutputStream压缩文件输入 / 输出流

ZipEntry压缩项

多个文件压缩

// 多个文件压缩

public static void main(String[] args) {

zipFile();

}

public static void zipFile() {

File file = new File("D:/temp");

File zipFile = new File("D:/temp.zip");

FileInputStream input = null;

try (ZipOutputStream zos = new ZipOutputStream(new FileOutputStream(zipFile))) {

// 添加注释

zos.setComment(new String("多个个文件压缩".getBytes(),"UTF-8"));

// 压缩过程

int temp = 0;

// 判断是否为文件夹

if (file.isDirectory()) {

File[] listFile = file.listFiles();

for (int i = 0; i < listFile.length; i++) {

// 定义文件的输出流

input = new FileInputStream(listFile[i]);

// 设置Entry对象

zos.putNextEntry(new ZipEntry(file.getName() +

File.separator + listFile[i].getName() ));

System.out.println("正在压缩: " + listFile[i].getName());

// 读取内容

while ((temp = input.read()) != -1) {

// 压缩输出

zos.write(temp);

}

// 关闭输入流

input.close();

}

}

} catch (Exception e) {

e.printStackTrace();

}

}

注意:压缩的文件夹不能有子目录,否则会报FileNotFoundException: D:\temp\test (拒绝访问。),这是由于input = new FileInputStream(listFile[i]);读取的文件类型是文件夹导致的

多个文件解压缩

// 多个文件解压缩

public static void main(String[] args) throws Exception{

// 待解压的zip文件,需要在zip文件上构建输入流,读取数据到Java中

File file = new File("C:\\Users\\Wong\\Desktop\\test.zip");

// 输出文件的时候要有文件夹的操作

File outFile = null;

// 实例化ZipEntry对象

ZipFile zipFile = new ZipFile(file);

// 定义解压的文件名

OutputStream out = null;

// 定义输入流,读取每个Entry

InputStream input = null;

// 每一个压缩Entry

ZipEntry entry = null;

// 定义压缩输入流,实例化ZipInputStream

try (ZipInputStream zipInput = new ZipInputStream(new FileInputStream(file))) {

// 遍历压缩包中的文件

while ((entry = zipInput.getNextEntry()) != null) {

System.out.println("解压缩 " + entry.getName().replaceAll("/", "") + " 文件");

// 定义输出的文件路径

outFile = new File("D:/" + entry.getName());

boolean outputDirectoryNotExsits = !outFile.getParentFile().exists();

// 当输出文件夹不存在时

if (outputDirectoryNotExsits) {

// 创建输出文件夹

outFile.getParentFile().mkdirs();

}

boolean outFileNotExists = !outFile.exists();

// 当输出文件不存在时

if (outFileNotExihttp://sts) {

if (entry.isDirectory()) {

outFile.mkdirs();

} else {

outFile.createNewFile();

}

}

boolean entryNotDirctory = !entry.isDirectory();

if (entryNotDirctory) {

input = zipFile.getInputStream(entry);

out = new FileOutputStream(outFile);

int temp = 0;

while ((temp = input.read()) != -1) {

out.write(temp);

}

input.close();

out.close();

System.out.println("解压缩成功");

}

}

} catch (Exception e) {

e.printStackTrace();

}

}

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:mybatis如何使用注解实现一对多关联查询
下一篇:免费数据接口api平台(免费API数据接口调用服务平台)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~