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,如需转载请自行联系原作者


相关文章
|
6月前
|
机器学习/深度学习 JSON Java
Java调用Python的5种实用方案:从简单到进阶的全场景解析
在机器学习与大数据融合背景下,Java与Python协同开发成为企业常见需求。本文通过真实案例解析5种主流调用方案,涵盖脚本调用到微服务架构,助力开发者根据业务场景选择最优方案,提升开发效率与系统性能。
1516 0
|
6月前
|
Java
Java的CAS机制深度解析
CAS(Compare-And-Swap)是并发编程中的原子操作,用于实现多线程环境下的无锁数据同步。它通过比较内存值与预期值,决定是否更新值,从而避免锁的使用。CAS广泛应用于Java的原子类和并发包中,如AtomicInteger和ConcurrentHashMap,提升了并发性能。尽管CAS具有高性能、无死锁等优点,但也存在ABA问题、循环开销大及仅支持单变量原子操作等缺点。合理使用CAS,结合实际场景选择同步机制,能有效提升程序性能。
|
6月前
|
Java 开发者
Java并发编程:CountDownLatch实战解析
Java并发编程:CountDownLatch实战解析
541 100
|
7月前
|
存储 缓存 Java
Java数组全解析:一维、多维与内存模型
本文深入解析Java数组的内存布局与操作技巧,涵盖一维及多维数组的声明、初始化、内存模型,以及数组常见陷阱和性能优化。通过图文结合的方式帮助开发者彻底理解数组本质,并提供Arrays工具类的实用方法与面试高频问题解析,助你掌握数组核心知识,避免常见错误。
|
5月前
|
存储 安全 Java
《数据之美》:Java集合框架全景解析
Java集合框架是数据管理的核心工具,涵盖List、Set、Map等体系,提供丰富接口与实现类,支持高效的数据操作与算法处理。
|
6月前
|
Java 开发者
Java 函数式编程全解析:静态方法引用、实例方法引用、特定类型方法引用与构造器引用实战教程
本文介绍Java 8函数式编程中的四种方法引用:静态、实例、特定类型及构造器引用,通过简洁示例演示其用法,帮助开发者提升代码可读性与简洁性。
|
5月前
|
存储 人工智能 算法
从零掌握贪心算法Java版:LeetCode 10题实战解析(上)
在算法世界里,有一种思想如同生活中的"见好就收"——每次做出当前看来最优的选择,寄希望于通过局部最优达成全局最优。这种思想就是贪心算法,它以其简洁高效的特点,成为解决最优问题的利器。今天我们就来系统学习贪心算法的核心思想,并通过10道LeetCode经典题目实战演练,带你掌握这种"步步为营"的解题思维。
|
6月前
|
安全 Java API
Java SE 与 Java EE 区别解析及应用场景对比
在Java编程世界中,Java SE(Java Standard Edition)和Java EE(Java Enterprise Edition)是两个重要的平台版本,它们各自有着独特的定位和应用场景。理解它们之间的差异,对于开发者选择合适的技术栈进行项目开发至关重要。
1097 1
|
7月前
|
存储 缓存 算法
Java数据类型与运算符深度解析
本文深入解析Java中容易混淆的基础知识,包括八大基本数据类型(如int、Integer)、自动装箱与拆箱机制,以及运算符(如&与&&)的使用区别。通过代码示例剖析内存布局、取值范围及常见陷阱,帮助开发者写出更高效、健壮的代码,并附有面试高频问题解析,夯实基础。
|
7月前
|
算法 Java 测试技术
零基础学 Java: 从语法入门到企业级项目实战的详细学习路线解析
本文为零基础学习者提供完整的Java学习路线,涵盖语法基础、面向对象编程、数据结构与算法、多线程、JVM原理、Spring框架、Spring Boot及项目实战,助你从入门到进阶,系统掌握Java编程技能,提升实战开发能力。
449 0

推荐镜像

更多
  • DNS