Apache commons-io实现多文件读取和写入
需求:
”E:/data/”目录下有四个文件夹,如下:

每个文件夹下有几个.csv文件,如下:

将每个文件夹下的.csv文件合并成一个以该文件夹命名的.csv文件。
做法:
找到“E:/data”这个目录,循环读取目录下的四个文件夹;
针对每个文件夹,循环读取目录下的文件列表;
将读取的文件写入要合并的文件中。
代码:
package com.file_readwrite; import java.io.File;
import java.io.IOException;
import java.util.Iterator;
import java.util.List; import org.apache.commons.io.FileUtils;
import org.apache.commons.io.LineIterator; public class FileTest {
public static void main(String[] args) {
combine();
}
public static void combine(){
File files=new File("E:/data/");
String dirctorys1[]=files.list();
for(int x=0; x<dirctorys1.length; x++){
File file=new File("E:/data//"+dirctorys1[x]+".csv");
File fs = new File("E:/data/"+dirctorys1[x]);
String dirctorys2[]=fs.list();
for(int i=0;i<dirctorys2.length;i++){
File f = new File("E:/data/"+dirctorys1[x]+"/"+dirctorys2[i]);
try {
List lines = FileUtils.readLines(f, "GBK");
FileUtils.writeLines(file, lines, true);
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
}
注意:
List lines = FileUtils.readLines(f, "GBK");
FileUtils.writeLines(file, lines, true);
方法public static void writeLines(File file, Collection<?> lines, boolean append)
实现了逐句写入一个文件,参数boolean append为"true"时表示添加文件,而不是新建新的文件。
当合并多个文件时必须设置为ture。
上面几行代码还可以用如下代码代替:
LineIterator it = FileUtils.lineIterator(f, "GBK");
while(it.hasNext()){
String line = it.nextLine();
FileUtils.writeStringToFile(file, line, true);
}
这是使用Apache commons-io提供的迭代器实现。
org.apache.commons.io.LineIterator类提供了一个灵活的方式与基于行的文件交互。
可以直接创建一个实例,或者使用FileUtils或IOUtils的工厂方法来创建。
此外,方法public static void writeStringToFile(File file, String data, boolean append)
实现了将字符串写入一个文件,参数boolean append为"true"时表示添加文件,而不是新建新的文件。
此参数必须设置为ture,否则结果文件中将只有一行数据。
或用如下代码代替:
List lines = FileUtils.readLines(f, "GBK");
Iterator<String> it = lines.iterator();
while(it.hasNext()){
String s = it.next();
FileUtils.writeStringToFile(file, s, true);
}
这是普通的方式,使用List固有的迭代器实现。
运行结果:

Apache commons-io实现多文件读取和写入的更多相关文章
- 使用Apache Commons IO组件读取大文件
Apache Commons IO读取文件代码如下: Files.readLines(new File(path), Charsets.UTF_8); FileUtils.readLines(new ...
- IO与文件读写---使用Apache commons IO包提高读写效率
觉得很不错,就转载了, 作者: Paul Lin 首先贴一段Apache commons IO官网上的介绍,来对这个著名的开源包有一个基本的了解:Commons IO is a library of ...
- Java (四)APACHE Commons IO 复制文件
上一篇:Java (三)APACHE Commons IO 常规操作 例1:复制文件 1 import java.io.File; 2 import java.io.IOException; 3 4 ...
- apache commons io包基本功能
1. http://jackyrong.iteye.com/blog/2153812 2. http://www.javacodegeeks.com/2014/10/apache-commons-io ...
- Apache Commons IO入门教程(转)
Apache Commons IO是Apache基金会创建并维护的Java函数库.它提供了许多类使得开发者的常见任务变得简单,同时减少重复(boiler-plate)代码,这些代码可能遍布于每个独立的 ...
- [转]Apache Commons IO入门教程
Apache Commons IO是Apache基金会创建并维护的Java函数库.它提供了许多类使得开发者的常见任务变得简单,同时减少重复(boiler-plate)代码,这些代码可能遍布于每个独立的 ...
- Apache Commons IO之FileUtils的常用方法
Apache Commons IO 在学习io流的时候研究(翻译)了一下这个,只有FileUtils的某些方法,并不全面,还请谅解 org.apache.commons.io 这个包下定义了基于 st ...
- apache.commons.io.FileUtils的常用操作
至于相关jar包可以到官网获取 http://commons.apache.org/downloads/index.html package com.wz.apache.fileUtils; impo ...
- apache commons io入门
原文参考 http://www.javacodegeeks.com/2014/10/apache-commons-io-tutorial.html Apache Commons IO 包绝对是 ...
随机推荐
- spring :概述
本章涵盖 spring's bean容器 探讨spring's 核心模块 强大的spring生态 spring 4新增内容 spring提供了众多的功能,但是这些功能都有基础的任务:让java开发变得 ...
- CMake 简介与使用
cross platform make的缩写. 是一个比make更高级的编译配置工具,它可以根据不同平台.不同的编译器,生成相应的Makefile或者vcproj项目文件.通过编写CMakeLists ...
- jxta 2.8x启动了
http://chaupal.github.io/ ———————————————————————————————————————————————————————————————————— 至少两个月 ...
- CSS隐藏滚动条但又能滚动,不用js实现
隐藏多余的内容,但是可以滑动查看 原理就在于padding-right:17px;把滚动条挤出去隐藏了
- EasyUI DataGrid 相同连续列合并
扩展方法:$.extend($.fn.datagrid.methods, { autoMergeCells: function(jq, fields) { return jq.each(functio ...
- 如何利用Emacs进行个人时间管理(GTD)
1. 简介 1.1 什么是GTD Get Things Done(GTD),是一套时间管理方法,面对生活中如下情况: 有很多事情要做 每件事情有主次之分 个人精力有限 我们需要随时很方便的了解我们下一 ...
- Eclipse 查找
Eclipse 查找 工作空间中查找 Eclipse 查找对话框中可以允许用户在指定工作空间上使用单词或字母模式来查找文件. 或者你可以在指定项目或在 package explorer 视图上选择好指 ...
- WPF开发简介教程
1/ VS中文件-新建-项目-WPF应用程序 2/ 左上角工具箱中有很多组件可以直接拖拽使用 3/ 双击组件,进入脚本功能编辑界面,如按钮: private void Button_Click_1(o ...
- Python 基础爬虫架构
基础爬虫框架主要包括五大模块,分别为爬虫调度器.url管理器.HTML下载器.HTML解析器.数据存储器. 1:爬虫调度器主要负责统筹其他四个模块的协调工作 2: URL管理器负责管理URL连接,维护 ...
- (四)DIH导入结构化数据
(四)DIH导入结构化数据 目前大多数的应用程序将数据存储在关系数据库(如oracle.sql server .mysql等).xml文件中.对这样的数据进行搜索是很常见的应用.所谓的DataImpo ...