java 解析excle和生成excle文档
2016-05-17 23:33
357 查看
只贴出关键代码,其他一概论之
java解析excle文件:
一般的操作需要上传再解析,曾经傻傻的以为可以上传的时候就直接解析,才发现大错特错了。
真实的基本流程为,excle上传到本地,得到保存在本地的路劲,读取该路径的excle文件,。
生成excle文件,并下载
说明,Label里面的参数为 Label(列,行,内容)
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(列,行,内容)
相关文章推荐
- java对世界各个时区(TimeZone)的通用转换处理方法(转载)
- java-注解annotation
- java-模拟tomcat服务器
- java-用HttpURLConnection发送Http请求.
- java-WEB中的监听器Lisener
- Android IPC进程间通讯机制
- Android Native 绘图方法
- Android java 与 javascript互访(相互调用)的方法例子
- 介绍一款信息管理系统的开源框架---jeecg
- 聚类算法之kmeans算法java版本
- java实现 PageRank算法
- PropertyChangeListener简单理解
- 自动共享和上传文件到兼容的托管站点
- c++11 + SDL2 + ffmpeg +OpenAL + java = Android播放器
- 插入排序
- 冒泡排序
- 堆排序
- 快速排序