网站更换域名seo网站推广排名
写文件
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