首发地址:http://blog.csdn.net/u014737138/article/details/38120403

不多说了 直接看代码:

下面的FileFind类首先是找到文件夹下面所有的txt文件,并且获取他们的绝对路径或者相对路径存放在数组中

public class FileFind {
@SuppressWarnings("rawtypes") /**
* 利用字符串的.endsWith()来判断后缀名
* 利用文件类的.listFiles()来获取一个文件夹下所有文件
*
* @param path
* @param data
* @return
*/
@SuppressWarnings({ "rawtypes", "unchecked" })
private static List getData(String path, List data) {
try{
File f = new File(path);
if (f.isDirectory()) {
File[] fs = f.listFiles();
for (int i = ; i < fs.length; i++) {
// 如果该文件夹下面还有文件夹,那么继续往下面去找,递归
data = getData(fs[i].getPath(), data);
}
} else if (f.getName().endsWith(".txt")) {
// 匹配文本文件,*.txt
data.add(f.getName());// 得到相对路径
} }catch(Exception e){
e.printStackTrace();
}
return data;
} /**
*
* @param path
* @param data
* @return data 返回文件的绝对路径
*/
@SuppressWarnings({ "rawtypes", "unchecked" })
public static List getFileAbsolutePath(String path, List data) {
try{
File f = new File(path);
if (f.isDirectory()) {
File[] fs = f.listFiles();
for (int i = ; i < fs.length; i++) {
// 如果该文件夹下面还有文件夹,那么继续往下面去找,递归
data = getFileAbsolutePath(fs[i].getPath(), data);
}
} else if (f.getName().endsWith(".txt")) {
// 匹配文本文件,*.txt
data.add(f.getAbsolutePath().toString());// 得到相对路径
// System.out.println(f.getAbsolutePath());// 得到绝对路径
} }catch(Exception e){
e.printStackTrace();
}
return data;
}
}

类GetStringByLocation获取文本文件内容,这个案例中只用了,readTEXT函数,按照\t读取字段内容

import java.io.BufferedReader;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.List; public class GetStringByLocation { /**
* 按照行读取文本文件的数据,每一行存入到list一维数组中
*
* @param list 用来存储读取的数据
* @param destFile 读取的文件路径
* @throws Exception 读取文件出错 抛出异常
*/
@SuppressWarnings({ "rawtypes", "unchecked" })
public void readTxt(List list, String destFile) throws Exception {
try{
BufferedReader reader = new BufferedReader(new FileReader(destFile));
String line = reader.readLine(); while (line != null) {
list.add(line);
line = reader.readLine();
} reader.close();
}catch(Exception e){
e.printStackTrace();
}
} /**
*
* @param list 存放读取的结果,按照每行的数据格式 \t读取每一个字段
* @param pathName 读取的文本文件路径
* @throws Exception 抛出异常
*/
@SuppressWarnings({ "rawtypes", "unchecked" })
public void readTEXT(List list,String pathName) throws Exception{
String text = null;
try
{
InputStreamReader read1 = new InputStreamReader(new FileInputStream(pathName));
BufferedReader br1 = new BufferedReader(read1);
while((text = br1.readLine())!=null)
{
/***相应操作***/
System.out.println(text);
String[] ss =text.split("\t"); for(int j=;j<ss.length;j++){
System.out.println(ss[j]);
list.add(ss[j]);
} text = br1.readLine();
}
br1.close();
}
catch(FileNotFoundException e)
{
System.out.println(e);
}
catch(IOException e)
{
System.out.println(e);
}
} /**
* 从文件读取数据
* @param path 文件路径
* @return 文件数据
*/
public static List<String> getFileData(String path)
{
List<String> result = new ArrayList<String>();
FileReader fr = null;
BufferedReader br = null; try
{
fr = new FileReader(path);
br = new BufferedReader(fr);
String str; while((str = br.readLine()) != null)
{
result.add(str);
}
}
catch(IOException e)
{
e.printStackTrace();
}
finally
{
try
{
if(fr != null)
{
fr.close();
} if(br != null)
{
br.close();
}
}
catch(IOException e)
{
e.printStackTrace();
}
} return result;
}
}

最后就是写入到Excel文件中去的主函数:

public class ExcelForAlibaba {
@SuppressWarnings("rawtypes")
public static void main(String[] args)
{ String targetfile = "E:/out.xls";// 输出的excel文件名
String worksheet = "InfoList";// 输出的excel文件工作表名
String[] title = { "A", "A", "A" };// excel工作表的标题 WritableWorkbook workbook;
try {
// 创建可写入的Excel工作薄,运行生成的文件在tomcat/bin下
// workbook = Workbook.createWorkbook(new File("output.xls")); OutputStream os = new FileOutputStream(targetfile);
workbook = Workbook.createWorkbook(os); WritableSheet sheet = workbook.createSheet(worksheet, ); // 添加第一个工作表 jxl.write.Label label;
System.out.println("title:"+title.length);
for (int i = ; i < title.length; i++) {
// Label(列号,行号 ,内容 )
label = new jxl.write.Label(i, , title[i]);
sheet.addCell(label);
} //添加内容:
String[] row = { "E", "E", "E" };// excel工作表的的行数据
jxl.write.Label label1;
System.out.println("row:"+row.length);
for(int i =;i<row.length;i++){
label1 = new jxl.write.Label(i, , row[i]); sheet.addCell(label1);
} try{
GetStringByLocation test = new GetStringByLocation();
FileFind filefind = new FileFind(); List absdata = new ArrayList();//存放文本文件的绝对路径 String path = "E:\\DD\DD\\test";//文件夹路径 absdata = filefind.getFileAbsolutePath(path, absdata);//获取文本文件的路径集,存放在数组中
int j=;//从第三行开始,写到Excel文件中 for (int m = ; m < absdata.size(); m++) {
//每一个文件进行操作,每一个文件里面的内容都放在list中,
List list = new ArrayList();//存放每一个文件的内容
test.readTEXT(list, absdata.get(m).toString());
for (int i = ; i < ; i++) {
//i表示第一列,第二列。。。。。。
jxl.write.Label labeltemp;
// System.out.println(list.get(i).toString());
labeltemp = new jxl.write.Label(i, j, list.get(i).toString());
sheet.addCell(labeltemp);
} j++;//从下一行开始写起
} }catch(Exception e){
e.printStackTrace();
} workbook.write();
workbook.close();
} catch (Exception e) {
e.printStackTrace();
}
System.out.println("end"); } }

以上代码经过测试完全没有问题。需要导入的包自己弄,需要自己写三个包

package org.txtOperate; GetStringByLocation
package org.file.operate; FileFind
package org.excelTest;man()

需要引用的各种第三方包:在main(0)中

import jxl.*;
import jxl.write.*;
import java.io.*;
import java.io.File.*;
import java.util.*; import org.file.operate.FileFind;
import org.txtOperate.GetStringByLocation;

转载请注明,交流请联系nlp30508@qq.com

批量处理txt文本文件到Excel文件中去----java的更多相关文章

  1. Java读取、写入、处理Excel文件中的数据(转载)

    原文链接 在日常工作中,我们常常会进行文件读写操作,除去我们最常用的纯文本文件读写,更多时候我们需要对Excel中的数据进行读取操作,本文将介绍Excel读写的常用方法,希望对大家学习Java读写Ex ...

  2. [SAP ABAP开发技术总结]客户端文本文件、Excel文件上传下载

    声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...

  3. Python:将爬取的网页数据写入Excel文件中

    Python:将爬取的网页数据写入Excel文件中 通过网络爬虫爬取信息后,我们一般是将内容存入txt文件或者数据库中,也可以写入Excel文件中,这里介绍关于使用Excel文件保存爬取到的网页数据的 ...

  4. 条形码的应用三-----------从Excel文件中读取条形码

    条形码的应用三------从Excel文件中读取条形码 介绍 上一篇文章,我向大家展示了生成多个条形码并存储到Excel文件中的一个方法.后来我又有了个想法:既然条码插入到excel中了,我可不可以从 ...

  5. 效率最高的Excel数据导入---(c#调用SSIS Package将数据库数据导入到Excel文件中【附源代码下载】) 转

    效率最高的Excel数据导入---(c#调用SSIS Package将数据库数据导入到Excel文件中[附源代码下载])    本文目录: (一)背景 (二)数据库数据导入到Excel的方法比较   ...

  6. C#可以获取Excel文件中Sheet的名字

    C#可以获取Excel文件中Sheet的名字吗 C#可以获取Excel文件中Sheet的名字吗 我试过WPS的表格可以 可以 要代码么 百度都有 [深圳]Milen(99696619)  14:13: ...

  7. 如何用Apache POI操作Excel文件-----如何在已有的Excel文件中插入一行新的数据?

    在POI的第一节入门中,我们提供了两个简单的例子,一个是如何用Apache POI新建一个工作薄,另外一个例子是,如果用Apache POI新建一个工作表.那么在这个章节里面,我将会给大家演示一下,如 ...

  8. 读取Excel文件中的单元格的内容和颜色

    怎样读取Excel文件中的单元格的内容和颜色 先创建一个Excel文件,在A1和A2中随意输入内容,设置A1的字体颜色为红色,A2的背景为黄色.需要 using Excel = Microsoft.O ...

  9. 从Excel文件中读取内容

    从Excel文件中读取内容 global::System.Web.HttpPostedFileBase file = Request.Files["txtFile"]; strin ...

随机推荐

  1. 201871010105-曹玉中《面向对象程序设计(java)》第十五周学习总结

    201871010105-曹玉中<面向对象程序设计(java)>第十五周学习总结 项目 内容 这个作业属于哪个过程 https://www.cnblogs.com/nwnu-daizh/ ...

  2. Netty粘包问题(六)

    netty使用tcp/ip协议传输数据,而tcp/ip协议是类似水流一样的数据传输方法.多次访问的时候可能出现粘包的问题,解决这种问题的方式有如下几种. 一.定长数据流 二.特殊结束符 三.

  3. centos7中运行ifconfig提示“-bash: ifconfig: command not found”解决方案

    linux系统查看ip地址常用命令是[ifconfig], CentOS 7.0最小安装是没有ifconfig命令怎么办? 1.用[ip addr]查看; 2.就是安装ifconfig命令 1.输入[ ...

  4. public.js

    //通过id名称获取元素对象 function getid(idName){ return document.getElementById(idName); } //随机获取min-max的随机整数 ...

  5. MySQL实战45讲学习笔记:第二十一讲

    一.引子 在上一篇文章中,我和你介绍了间隙锁和 next-key lock 的概念,但是并没有说明加锁规则.间隙锁的概念理解起来确实有点儿难,尤其在配合上行锁以后,很容易在判断是否会出现锁等待的问题上 ...

  6. Comet OJ - Contest #13-C2

    Comet OJ - Contest #13-C2 C2-佛御石之钵 -不碎的意志-」(困难版) 又是一道并查集.最近做过的并查集的题貌似蛮多的. 思路 首先考虑,每次处理矩形只考虑从0变成1的点.这 ...

  7. mysql修改windows下的data目录

    在windows下,安装完mysql后,建议把数据目录(data目录)移动到非系统目录,避免系统出问题的时候还原. 1.在d盘创建一个mysqldata 2.给新文件增加权限NetworkServic ...

  8. 重启服务器后Docker容器暴露的端口外网突然访问不了!!

    *:first-child { margin-top: 0 !important; } .markdown-body>*:last-child { margin-bottom: 0 !impor ...

  9. CentOS7 GitLab 安装

    1.安装依赖 $ yum -y install policycoreutils openssh-server openssh-clients postfix $ yum install policyc ...

  10. 使用velero进行kubernetes灾备

    使用velero可以对集群进行备份和恢复,降低集群DR造成的影响.velero的基本原理就是将集群的数据备份到对象存储中,在恢复的时候将数据从对象存储中拉取下来.可以从官方文档查看可接收的对象存储,本 ...