打印系列 —— 利用jxl生成Excel

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是成功的提示页面-->

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值