java 解析excle和生成excle文档

简介:

只贴出关键代码,其他一概论之



java解析excle文件:


Workbook book = Workbook.getWorkbook(new File(fileName)) ; //filename为需要解析的excle 
Sheet sheet = book.getSheet(0); 
int rows = sheet.getRows();
int celllength = sheet.getRow(0).length;//只获取标题这么多列的数据,其他的就不管了
List<List> all_data = new ArrayList();
for(int i = 1; i < rows; i++) {   //i=1,是因为需要将第一行标题去掉
  List data = new ArrayList();
  Cell [] cell = sheet.getRow(i);                        
  for(int j=0; j<celllength; j++) {
	  String content="";
	  try{
	     //将第i行,第j列的数据保存
	     content=sheet.getCell(j, i).getContents(); 
	  }catch(Exception e){
		  content="";
	  }
	  
	  data.add(content);
  }
  //最后所有的数据都保存在all_data里面啦
  all_data.add(data);
}


一般的操作需要上传再解析,曾经傻傻的以为可以上传的时候就直接解析,才发现大错特错了。

真实的基本流程为,excle上传到本地,得到保存在本地的路劲,读取该路径的excle文件,。


生成excle文件,并下载

response.setContentType("application/vnd.ms-excel;charset=UTF-8");
String filename = new String("工资模板.xls".getBytes("gb2312"),"ISO8859-1");
response.addHeader("Content-Disposition", "filename=" + filename);
OutputStream os=response.getOutputStream();
//创建工作薄
WritableWorkbook workbook = Workbook.createWorkbook(os);
WritableSheet sheet = workbook.createSheet("First Sheet",0);//一个excle文件可以有多个sheet

//创建标题,假设只有2列
Label l = new Label(0,0,"员工编号");
sheet.addCell(l);
l = new Label(1,0,"姓名");
sheet.addCell(l);

//开始添加数据了
l = new Label(0,1,"01");
l = new Label(1,1,"张三");
sheet.addCell(l);

l = new Label(0,2,"02");
l = new Label(1,2,"李四");
sheet.addCell(l);

//直接下载,如果是需要写在某个位置的话,则另当别论
 workbook.write(); 
 workbook.close();    
 os.flush();
 os.close();


说明,Label里面的参数为   Label(列,行,内容)






      本文转自布拉君君 51CTO博客,原文链接:http://blog.51cto.com/5148737/1774554,如需转载请自行联系原作者


相关文章
|
23小时前
|
存储 安全 Java
Java并发编程中的高效数据结构:ConcurrentHashMap解析
【4月更文挑战第25天】在多线程环境下,高效的数据访问和管理是至关重要的。Java提供了多种并发集合来处理这种情境,其中ConcurrentHashMap是最广泛使用的一个。本文将深入分析ConcurrentHashMap的内部工作原理、性能特点以及它如何在保证线程安全的同时提供高并发性,最后将展示其在实际开发中的应用示例。
|
1天前
|
Java
Java输入输出流详细解析
Java输入输出流详细解析
Java输入输出流详细解析
|
2天前
|
存储 Java C++
Java集合篇之深度解析Queue,单端队列、双端队列、优先级队列、阻塞队列
Java集合篇之深度解析Queue,单端队列、双端队列、优先级队列、阻塞队列
13 0
|
6天前
|
JavaScript Java 测试技术
基于Java的电影评论系统的设计与实现(源码+lw+部署文档+讲解等)
基于Java的电影评论系统的设计与实现(源码+lw+部署文档+讲解等)
21 0
|
6天前
|
JavaScript Java 测试技术
基于Java的在线日语培训平台的设计与实现(源码+lw+部署文档+讲解等)
基于Java的在线日语培训平台的设计与实现(源码+lw+部署文档+讲解等)
23 0
|
6天前
|
JavaScript Java 测试技术
基于Java的同城蔬菜配送管理系统的设计与实现(源码+lw+部署文档+讲解等)
基于Java的同城蔬菜配送管理系统的设计与实现(源码+lw+部署文档+讲解等)
11 0
|
6天前
|
JavaScript Java 测试技术
基于Java的心理预约咨询管理系统的设计与实现(源码+lw+部署文档+讲解等)
基于Java的心理预约咨询管理系统的设计与实现(源码+lw+部署文档+讲解等)
22 0
基于Java的心理预约咨询管理系统的设计与实现(源码+lw+部署文档+讲解等)
|
6天前
|
JavaScript Java 测试技术
基于Java的税务门户网站的设计与实现(源码+lw+部署文档+讲解等)
基于Java的税务门户网站的设计与实现(源码+lw+部署文档+讲解等)
5 0
|
6天前
|
JavaScript Java 测试技术
基于Java的高校毕业生就业管理系统的设计与实现(源码+lw+部署文档+讲解等)
基于Java的高校毕业生就业管理系统的设计与实现(源码+lw+部署文档+讲解等)
22 0
基于Java的高校毕业生就业管理系统的设计与实现(源码+lw+部署文档+讲解等)
|
6天前
|
JavaScript Java 测试技术
基于Java的家纺用品销售管理系统的设计与实现(源码+lw+部署文档+讲解等)
基于Java的家纺用品销售管理系统的设计与实现(源码+lw+部署文档+讲解等)
17 0

推荐镜像

更多