Kotlin技术-文件操作如此简单

写文件

Java

在java里对文件的读写往往是先从选择流开始,操作完文件还要把留一一关掉,更标准的方式还要加个finnly 再关一次流,总之一句话就是麻烦。

public class FileUtil {
 
    //保存文本文件
    public static void saveText(String path, String txt) {
        try {
            FileOutputStream fos = new FileOutputStream(path);
            fos.write(txt.getBytes());
            fos.close();
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
 
    //读取文本文件
    public static String openText(String path) {
        String readStr = "";
        try {
            FileInputStream fis = new FileInputStream(path);
            byte[] b = new byte[fis.available()];
            fis.read(b);
            readStr = new String(b);
            fis.close();
        } catch (Exception e) {
            e.printStackTrace();
        }
        return readStr;
    }
}

Kotlin 写文件

  1. writeText 覆盖写入文本
  2. appendText 往源文件追加文本
  3. writeBytes 覆盖写入字节数组
  4. appendBytes 追加字节数组
    //把文本写入文件
    File(file_path).writeText(content)

Kotlin 读文件

  1. readText : 读取文本形式的文件内容。
  2. readLines : 按行读取文件内容。返回一个字符串的List,文件有多少行,队列中就有多少个元素。
  3. readBytes : 读取字节数组形式的文件内容。
    //读取文件的文本内容
    val content = File(file_path).readText()
 //readBytes读取字节数组形式的文件内容
    val bytes = File(file_path).readBytes()

Kotlin 遍历文件夹

因为Kotlin把目录遍历这个功能重新梳理了一下,归纳为FileTreeWalk文件树,通过给文件树设置各式各样的参数与条件,即可化繁为简,轻轻松松获取文件的搜索结果。文件树的使用很简单,首先调用File对象的walk方法得到FileTreeWalk实例,接着依次为该实例设置具体的条件,包括遍历深度、是否匹配文件夹、文件扩展名,以及最后的文件队列循环处理。

    var fileNames: MutableList<String> = mutableListOf()
    //在该目录下走一圈,得到文件目录树结构
    val fileTree: FileTreeWalk = File(mPath).walk()
    fileTree.maxDepth(1) //需遍历的目录层级为1,即无需检查子目录
            .filter { it.isFile } //只挑选文件,不处理文件夹
            .filter { it.extension in listOf("png","jpg") } //选择扩展名为png和jpg的图片文件
            .forEach { fileNames.add(it.name) } //循环处理符合条件的文件

摘录:http://blog.csdn.net/aqi00/article/details/75283548

你可能感兴趣的:(知识积累,android,kotlin,file)