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(列,行,内容)

时间: 2025-01-14 22:17:59

java 解析excle和生成excle文档的相关文章

java通过word模板生成word文档

介绍 上次公司项目需要一个生成word文档的功能,有固定的模板根据业务填充数据即可,由于从来没做过,项目也比较着急于是去网上找有没有合适的工具类,找了好几种,看到其中有freeMark模板生成比较靠谱于是采用这个,正常生成成功了还挺高兴的于是修改优化部署测试,出问题了,由于我一直使用wps可以正常打开,但是同事使用office打不开,于是各种查找原因都没好,于是只能转变思路又试了两种还是不好用,直到发现这款模板生成 poi-tl 真的做的很不错,而且是国人写的,关于学习这个东西还是看官方文档的好

【Java】使用Eclipse生成API文档

据说某些公司需要员工们不仅要写好程序,而且要写好API,对于一些编程大神来说,写API是一件麻烦的事情, 其实Eclipse能够轻松地生成API来忽悠人,尤其是你讨厌的根本不会写代码的上司. 当然,这些API根本就不知道有什么用,还不如当面跟你的队友好好解释一下每一句是干什么的,还不如在你的Java文件中注释好每一句话. 1.对于你要生成的API的工程或者某个JAVA文件点右键,选择Export... 2.在弹出的窗口中找到了Javadoc,点下一步-- 3.之后设置好要导出的类的权限与导出目录

利用Java动态生成 PDF 文档

利用Java动态生成 PDF 文档,则需要开源的API.首先我们先想象需求,在企业应用中,客户会提出一些复杂的需求,比如会针对具体的业务,构建比较典型的具备文档性质的内容,一般会导出PDF进行存档.那么目前最佳的解决方案,你可能会想到 iText ,对没错... iText+(Velocity / Freemarker)可以实现.不过据我熟悉,iText本身提供的HTML解析器还是不够强大,许多HTML标签和属性无法识别,更悲催的是简单的CSS它不认识,排版调整样式会让你头大的.不要失望,接下来

java使用freemarker 生成word文档

java 生成word文档 最近需要做一个导出word的功能, 在网上搜了下, 有用POI,JXL,iText等jar生成一个word文件然后将数据写到该文件中,API非常繁琐而且拼出来的样式也不美观,于是选择了另一种方式----feemarker基于word模板的导出方式, 这种方式非常简单而且导出的样式美观, 其原理就是先做一个word模板, 该模板中变量数据用${xxx}这种方式填写, 然后再导出时只需读取模板然后用相应的数据替换其中的${xxx}即可. 一,简单模板导出(不含图片, 不含

dom4j解析和生成XML文档

解析XML的两种方法 package cnslp.dom4j.com; import java.io.File; import java.util.Iterator; import org.dom4j.Attribute; import org.dom4j.Document; import org.dom4j.Element; import org.dom4j.io.SAXReader; /**  * Created by cnslp on 2017/5/12 0012.  * 解析XML文档的

读thinking in java的收获(二) --eclipse生成javadoc文档

最开始学习java语言的时候学过生成javadoc不过当时只是用windows命令行生成.读了这里的javadoc温故而知新发现其实我们做的项目就用到了一些注释,只是没有用eclipse 生成这份文档,通过查阅,最终补全了这份知识. 一.书中的代码: <pre name="code" class="java">//:object/HelloDate.java package unit2; import java.util.Date; /** * The

Java Web项目中使用Freemarker生成Word文档

Web项目中生成Word文档的操作屡见不鲜,基于Java的解决方案也是很多的,包括使用Jacob.Apache POI.Java2Word.iText等各种方式,其实在从Office 2003开始,就可以将Office文档转换成XML文件,这样只要将需要填入的内容放上${}占位符,就可以使用像Freemarker这样的模板引擎将出现占位符的地方替换成真实数据,这种方式较之其他的方案要更为简单. 下面举一个简单的例子,比如在Web页面中填写个人简历,然后点击保存下载到本地,效果图如下所示. 打开下

java通过freemarket生成word文档

1.使用freemarker的原因是:由于POI和ITEXT在处理复杂word文档格式时欠缺,尤其在生成WORD文档时,(其他处理word的工具需要动态加载windows动态链接库,有些还要收费),并且需求要在WORD指定位置插入图片,所以在参考了POI和ITEXT官网处理WORD和网络上其他处理WORD的工具后,发现freemarker可以通过设定WORD模板,经过处理生成ftl文件后,可直接通过freemarker的工具jar包可以生成指定位置的WORD文件.(不过用模板生成有个别缺点,一是

Java iText使用PDF模板生成PDF文档

我们系统需要生成一个可以打印的PDF文档,老板给了我一个Word文档,按照这个Word文档的格式生成PDF文档. 第一步:下载AdobeAcrobat DC,必须使用这个来制作from域. 第二步:使用AdobeAcrobat DC将Word导成PDF文档. 第三步:由于还要加水印的效果,所以还是使用AdobeAcrobat DC来添加水印,非常方便: 添加水印的方法:使用AdobeAcrobat DC打开PDF文档,"工具"->"编辑PDF"->&qu

JAVA如何在eclipose中生成帮助文档

JAVA中注释有三种   1 单行注释 //+内容      2 多行注释  /* 内容 */  3 文档注释  /**内容*/       其中单行注释和多行注释是用于方法里面的注释 ,文档注释是用来注释类的成员和方法.   帮助文件是用多行注释实现的,用的程序是JAVA中jdk目录下bin目录JAVAdoc.exe. 首先 打开eclipose,找到一个需要生成帮助文档的工程.工程里面的类都是用多行注释标记了方法和属性的.比如 package java4_10; /** * * @autho