jxl的安装:
主要就是将jxl的包放在WEB-INF的classes下面(如果下载到的是.jar文件,就放在lib下面).别忘了将jxl包中的common文件夹也放在WEB-INF下面.

jxl的使用:
主要的功能就是读Excel文件和写Excel文件

读:
读的时候是这样的一个思路,先用一个输入流(InputStream)得到Excel文件,然后用jxl中的Workbook得到工作薄,用Sheet从工作薄中得到工作表,用Cell得到工作表中得某个单元格.
InputStream->Workbook->Sheet->Cell,就得到了excel文件中的单元格

代码:

  1. <%@ page contentType="text/html; charset=gb2312" %>
  2. <%@ page import="java.io.*,jxl.*,jxl.write.*,jxl.write.*,jxl.format.*" %>
  3. String path="c://excel.xls";//Excel文件URL
  4. InputStream is = new FileInputStream(path);//写入到FileInputStream
  5. jxl.Workbook wb = Workbook.getWorkbook(is); //得到工作薄
  6. jxl.Sheet st = wb.getSheet(0);//得到工作薄中的第一个工作表
  7. Cell cell=st.getCell(0,0);//得到工作表的第一个单元格,即A1
  8. String content=cell.getContents();//getContents()将Cell中的字符转为字符串
  9. wb.close();//关闭工作薄
  10. is.close();//关闭输入流 还可以通过Sheet的getRows(),getColumns()方法得到行数列数,并用于循环控制,输出一个sheet中的所有内容.

我们可以通过Sheet的getCell(x,y)方法得到任意一个单元格,x,y和excel中的坐标对应.
例如A1对应(0,0),A2对应(0,1),D3对应(3,2).Excel中坐标从A,1开始,jxl中全部是从0开始.

写:
往Excel中写入内容主要是用jxl.write包中的类.
思路是这样的:
OutputStream<-WritableWorkbook<-WritableSheet<-Label
这里面Label代表的是写入Sheet的Cell位置及内容.
代码:

  1. <%@ page contentType="text/html; charset=gb2312" %>
  2. <%@ page import="java.io.*,jxl.*,jxl.write.*,jxl.write.*,jxl.format.*" %>
  3. OutputStream os=new FileOutputStream("c://test.xls");//输出的Excel文件URL
  4. WritableWorkbook wwb = Workbook.createWorkbook(os);//创建可写工作薄
  5. WritableSheet ws = wwb.createSheet("sheet1", 0);//创建可写工作表
  6. Label labelCF=new Label(0, 0, "hello");//创建写入位置和内容
  7. ws.addCell(labelCF);//将Label写入sheet中
  8. //Label的构造函数Label(int x, int y,String aString)xy意同读的时候的xy,aString是写入的内容.
  9. WritableFont wf = new WritableFont(WritableFont.TIMES, 12, WritableFont.BOLD, false);
  10. //设置写入字体
  11. WritableCellFormat wcfF = new WritableCellFormat(wf);//设置CellFormat
  12. Label labelCF=new Label(0, 0, "hello");//创建写入位置,内容和格式

Label的另一构造函数Label(int c, int r, String cont, CellFormat st)可以对写入内容进行格式化,设置字体及其它的属性.

现在可以写了
wwb.write();
写完后关闭
wwb.close();
输出流也关闭吧
os.close;

OK,只要把读和写结合起来,就可以在N个Excel中读取数据写入你希望的Excel新表中,还是比较方便的.

下面是一个比较完整的JXL生成Excel的例子:
代码如下:
test.jsp

  1. <%@ taglib uri="/WEB-INF/struts-html.tld" prefix="html" %>
  2. <html:html>
  3. <html:button property="button" οnclick="printAll()">
  4. DownLoad
  5. </html:button>
  6. </html:html>
  7. <script language='javascript'>
  8. function printAll(){ location.href="<%=request.getContextPath()%>/download.do"; }
  9. </script>

DownloadAction.java

  1. import org.apache.struts.action.*;
  2. import javax.servlet.http.*;
  3. import java.io.OutputStream;
  4. import test.whw.upload.ExcelBean;
  5. public class DownloadAction extends Action {
  6. public ActionForward execute(ActionMapping mapping,
  7. ActionForm form,
  8. HttpServletRequest request,
  9. HttpServletResponse response)
  10. throws Exception {
  11. try{
  12. String fname = "test";//Excel文件名
  13. OutputStream os = response.getOutputStream();//取得输出流
  14. response.reset();//清空输出流
  15. response.setHeader("Content-disposition", "attachment; filename=" + fname + ".xls");
  16. //设定输出文件头
  17. response.setContentType("application/msexcel");//定义输出类型
  18. ExcelBean eb = new ExcelBean();
  19. eb.expordExcel(os);//调用生成excel文件bean
  20. }catch(Exception e){
  21. System.out.println(e);
  22. }
  23. return mapping.findForward("display");
  24. }
  25. }

ExcelBean.java

  1. package test.whw.upload;
  2. import java.io.*;
  3. import jxl.*;
  4. import jxl.write.*;
  5. import jxl.format.*;
  6. import java.util.*;
  7. import java.awt.Color;
  8. public class ExcelBean {
  9. public ExcelBean(){}
  10. public String expordExcel(OutputStream os)throws Exception{
  11. jxl.write.WritableWorkbook wbook = Workbook.createWorkbook(os); //建立excel文件
  12. String tmptitle = "测试文件"; //标题
  13. jxl.write.WritableSheet wsheet = wbook.createSheet("第一页", 0); //sheet名称
  14. //设置excel标题
  15. jxl.write.WritableFont wfont = new jxl.write.WritableFont(
  16. WritableFont.ARIAL, 16,
  17. WritableFont.BOLD, false, jxl.format.UnderlineStyle.NO_UNDERLINE,
  18. jxl.format.Colour.BLACK);
  19. jxl.write.WritableCellFormat wcfFC = new jxl.write.WritableCellFormat(
  20. wfont);
  21. jxl.write.Label wlabel1;
  22. wlabel1 = new jxl.write.Label(5, 0, tmptitle, wcfFC);
  23. wsheet.addCell(wlabel1);
  24. wfont = new jxl.write.WritableFont(
  25. WritableFont.ARIAL, 14,
  26. WritableFont.BOLD, false, jxl.format.UnderlineStyle.NO_UNDERLINE,
  27. jxl.format.Colour.BLACK);
  28. wcfFC = new jxl.write.WritableCellFormat(
  29. wfont);
  30. jxl.write.Label wlabel;
  31. wlabel = new jxl.write.Label(0, 0, "写入内容");
  32. wsheet.addCell(wlabel); //
  33. //合并单元格mergeCells(行,列,行,列);
  34. wsheet.mergeCells(3,1,5,1);
  35. wbook.write(); //写入文件
  36. wbook.close();
  37. os.close();
  38. return "success";
  39. }
  40. }

struts-config.xml

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!DOCTYPE struts-config PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 1.1//EN" "http://jakarta.apache.org/struts/dtds/struts-config_1_1.dtd">
  3. <struts-config>
  4. <action-mappings>
  5. <action type="test.whw.upload.DownloadAction" path="/download">
  6. <forward name="display" path="/display.jsp" />
  7. </action>
  8. </action-mappings>
  9. </struts-config>
  10. <!--display.jsp是成功的提示页面-->

打印系列 —— 利用jxl生成Excel相关推荐

  1. 利用owc生成excel并且显示在页面

    主要利用OWC生成Excel,画表头和显示从数据库读出来的数据,然后显示在前台页面上,无需客户端安装office,只需要安装owc.一年以前写的,似乎很烦锁,哪位有高见请指教! 后面利用OWC操作EX ...

  2. java的json导出excel_利用json生成excel表格

    起因: 之前利用反射生成excel导出,这个组件本来挺好用的,结果,坑爹的本地研发没有问题,生产环境却有问题.不知道什么原因直接导致服务重启,还重新加载类,直接导致jvm的永久区内存溢出. 异常: j ...

  3. JXL生成Excel,并提供下载(2:提供下载)

    实现效果: 项目中使用JXL生成Excel,使生成的Excel可以让用户下载,如下图 一.生成Excel 二.提供下载 实现思路: 1.页面使用form表单提交方式(Ajax提交方式,我这里不行) 2 ...

  4. java使用jxl生成excel表格,jsp使用js下载excel文件xls

    java使用jxl生成excel表格,jsp使用js下载excel文件 后端代码 maven jar包 主体代码逻辑 引入的jar包 具体代码段 重点详解 表头和表格内容两种格式 直接将 HttpSe ...

  5. JXL生成EXCEL时单元格设置为数值却展示货币或自定义的问题处理

    前言: 以下内容为个人见解,勿喷,欢迎有更好解决方法的大佬指点 问题起源: 最近项目中有一个这样的需求:根据后台数据生成Excel后转存到服务器上供用户进行下载.这本来是一个比较常见的需求,不存在什么 ...

  6. 利用POI生成EXCEL报表(通过web页面导出后台数据)

    很多时候需要将数据利用浏览器进行导出,这个时候我们就可以采用Apache的POI进行实现通过web页面实现Excel导出后台数据,并且以.xlsx的形式下载到本地,也就是excel表格形式. 首先先下 ...

  7. Java利用POI生成Excel强制换行

    前一段时间在做一个学校排课系统时,有一个地方需要利用把课程表生成excel汇出给客户,由于之前用excel都只是简单的应用,在单元格里都是用自动换行,而这次可能需要用到手动强制换行.  于是我在网上找 ...

  8. poi jxl 生成EXCEL 报表

    http://www.iteye.com/topic/611329 前2天后台系统需要生成报表,正好抽时间复习了一下之前做过的JAVA生成EXCEL,下面介绍POI 和JXL 生成报表的2种方式. 1 ...

  9. 利用poi生成excel考勤表

    今天利用了Apache poi 编写了一个生成excel的考勤表,Apache poi链接地址为http://poi.apache.org/,代码如下: package com.pom;import ...

最新文章

  1. 【SCOI 2008】奖励关
  2. ubuntu root默认密码(初始密码)
  3. 《AngularJS实战》——3.1 模板中的过滤器
  4. Socket经验记录
  5. 每3位新码农中就有2个是单身?来自31000人的调查报告显示……
  6. 安装Exchange Server 2013
  7. mysql 几个外键类型_mysql – 选择每个外键类型的最高记录
  8. String、StringBuffer、StringBuilder三者的区别
  9. 第二季-专题0-课程规划
  10. 用React加CSS3实现微信拆红包动画
  11. 从遥感影像到土地利用转移矩阵
  12. 微信公众号 | 适合程序员的公众号排版
  13. [转载]Geronimo 叛逆者,第 8 部分: 未来的 Apache Geronimo
  14. 员工接私单可不可以追究刑事责任
  15. Android N 程序适配要点
  16. arctanx麦克劳林公式推导过程_三角函数的求导过程
  17. autojs自定义Switch
  18. 终极解决Excel科学计数、日期变#号等问题
  19. 清空 通讯录 android,安卓 通讯录 清除数据恢复
  20. 力扣刷题全局变量WA,局部变量AC的问题

热门文章

  1. Axisfault faultcode:Server.userException异常
  2. 网络流行伤感日志:如果有一天,我从你的世界消失了
  3. php判断mysql表的字段_tp6 获取数据库某个表的所有字段名称_php菜鸟技术天地-CSDN博客...
  4. webpack抽离css,压缩css代码 和 js代码
  5. 星际官方小说《刀锋女王》——第4章
  6. 2019年区块链教育培训课程研究报告 |链塔智库
  7. 高精度定位系统:地铁隧道人员定位智能巡检
  8. 华为开发者大会2023(Cloud)之旅
  9. 铁匠smith_铁匠中的独特角色阴影
  10. 微信小程序|基于小程序+C#制作一个聊天系统