写文件
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 写文件
- writeText 覆盖写入文本
- appendText 往源文件追加文本
- writeBytes 覆盖写入字节数组
- appendBytes 追加字节数组
//把文本写入文件
File(file_path).writeText(content)
Kotlin 读文件
- readText : 读取文本形式的文件内容。
- readLines : 按行读取文件内容。返回一个字符串的List,文件有多少行,队列中就有多少个元素。
- 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