zoukankan      html  css  js  c++  java
  • IOUtils和FileUtils的学习笔记

    pom文件导入依赖import org.apache.commons.io.FileUtils;

    <dependency>
        <groupId>commons-io</groupId>
        <artifactId>commons-io</artifactId>
        <version>2.5</version>
    </dependency>

    https://blog.csdn.net/quanzhanjavabiji/article/details/73936240

    FieUtils类中常用方法的介绍

    打开FileUtils的api文档,我们抽出一些工作中比较常用的方法,进行总结和讲解。总结如下:

    cleanDirectory:清空目录,但不删除目录

    contentEquals:比较两个文件的内容是否相同

    copyDirectory:将一个目录内容拷贝到另一个目录。可以通过FileFilter过滤需要拷贝的文件。

    copyFile:将一个文件拷贝到一个新的地址

    copyFileToDirectory:将一个文件拷贝到某个目录下

    copyInputStreamToFile:将一个输入流中的内容拷贝到某个文件

    deleteDirectory:删除目录

    deleteQuietly:删除文件

    listFiles:列出指定目录下的所有文件

    openInputSteam:打开指定文件的输入流

    readFileToString:将文件内容作为字符串返回

    readLines:将文件内容按行返回到一个字符串数组中

    size:返回文件或目录的大小

    write:将字符串内容直接写到文件中

    writeByteArrayToFile: 将字节数组内容写到文件中

    writeLines:将容器中的元素的toString方法返回的内容依次写入文件中

    writeStringToFile:将字符串内容写到文件中

    代码演示

    【示例1】:读出某个文件的内容,并打印在控制台上(只需一行代码!)

    package com.bjsxt.test.fileutils;

    import java.io.File;

    import org.apache.commons.io.FileUtils;

    public class Demo01 {

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

                String content = FileUtils.readFileToString(new File("d:/a.txt"),"gbk");

                System.out.println(content);

            }

    }


    示例1  运行效果图

    【示例2】:目录拷贝,并且使用FileFilter过来目录和文件名字html结尾的文件。

    package com.bjsxt.test.fileutils;

    import java.io.File;

    import java.io.FileFilter;

    import org.apache.commons.io.FileUtils;

    public class Demo02 {

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

              FileUtils.copyDirectory(new File("d:/aaa"), new File("d:/bbb"), new FileFilter() {

                @Override

                public boolean accept(File pathname) {

                    

                    //拷贝目录或html结尾的文件

                    if(pathname.isDirectory()||pathname.getName().endsWith("html")){

                        return true;

                    }else{

                        return false;

                    }

                }

            });

        }

    }


     示例2 目录拷贝结果图

    IOUtils妙用

    打开IOUtils的api文档,我们发现他的方法大部分都是重载的。所以,我们理解他的方法并不是难事。因此,对于他方法的用法总结如下:

    buffer方法:将传入的流进行包装,变成缓冲流。并可以通过参数指定缓冲大小。

    closeQueitly方法:关闭流

    contentEquals方法:比较两个流中的内容是否一致

    copy方法:将输入流中的内容拷贝到输出流中,并可以指定字符编码。

    copyLarge方法:将输入流中的内容拷贝到输出流中,适合大于2G内容的拷贝。

    lineIterator方法:返回可以迭代每一行内容的迭代器

    read方法:将输入流中的部分内容读入到字节数组中

    readFully方法:将输入流中的所有内容读入到字节数组中

    readLine方法:读入输入流内容中的一行

    toBufferedInputStream,toBufferedReader:将输入转为带缓存的输入流

    toByteArray,toCharArray:将输入流的内容转为字节数组、字符数组。

    toString:将输入流或数组中的内容转化为字符串

    write方法:向流里面写入内容

    writeLine方法:向流里面写入一行内容

    我们没有必要对每个方法做测试,只是演示一下读入d:/a.txt文件内容到程序中,并转成String对象,打印出来。

    package com.bjsxt.test.fileutils;

    import java.io.*;

    import org.apache.commons.io.IOUtils;

    public class Demo03 {

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

            String content = IOUtils.toString(new FileInputStream("d:/a.txt"),"gbk");

            System.out.println(content);

        }

    }

     readLines                                                                                                                 

    readLines方法可以从流中读取内容,并转换为String的list

    readLines(inputstream)
    readLines(inputstream,charset)
    readLines(inputstream,encoding)
    readLines(reader)

    这个方法极大简化了之前原始的读取方法:

     @Test
        public void readLinesTest(){
            try{
                InputStream is = new FileInputStream("D://test1.txt");
                List<String> lines = IOUtils.readLines(is);
                for(String line : lines){
                    System.out.println(line);
                }
            } catch (FileNotFoundException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
  • 相关阅读:
    Python3标准库:fnmatch UNIX式glob模式匹配
    Python3标准库:glob文件名模式匹配
    Python3标准库:pathlib文件系统路径作为对象
    Python3标准库:os.path平台独立的文件名管理
    Python3标准库:statistics统计计算
    36-Docker 的两类存储资源
    第四章-操作列表
    35-外部世界如何访问容器?
    34-容器如何访问外部世界?
    33-容器间通信的三种方式
  • 原文地址:https://www.cnblogs.com/zhou-test/p/10001270.html
Copyright © 2011-2022 走看看