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文件中的单元格
代码:
我们可以通过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位置及内容.
代码:
- <%@ page contentType="text/html; charset=gb2312" %>
- <%@ page import="java.io.*,jxl.*,jxl.write.*,jxl.write.*,jxl.format.*" %>
- OutputStream os=new FileOutputStream("c://test.xls");//输出的Excel文件URL
- WritableWorkbook wwb = Workbook.createWorkbook(os);//创建可写工作薄
- WritableSheet ws = wwb.createSheet("sheet1", 0);//创建可写工作表
- Label labelCF=new Label(0, 0, "hello");//创建写入位置和内容
- ws.addCell(labelCF);//将Label写入sheet中
- //Label的构造函数Label(int x, int y,String aString)xy意同读的时候的xy,aString是写入的内容.
- WritableFont wf = new WritableFont(WritableFont.TIMES, 12, WritableFont.BOLD, false);
- //设置写入字体
- WritableCellFormat wcfF = new WritableCellFormat(wf);//设置CellFormat
- 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
- <%@ taglib uri="/WEB-INF/struts-html.tld" prefix="html" %>
- <html:html>
- <html:button property="button" onclick="printAll()">
- DownLoad
- </html:button>
- </html:html>
- <script language='javascript'>
- function printAll(){ location.href="<%=request.getContextPath()%>/download.do"; }
- </script>
DownloadAction.java
- import org.apache.struts.action.*;
- import javax.servlet.http.*;
- import java.io.OutputStream;
- import test.whw.upload.ExcelBean;
- public class DownloadAction extends Action {
- public ActionForward execute(ActionMapping mapping,
- ActionForm form,
- HttpServletRequest request,
- HttpServletResponse response)
- throws Exception {
- try{
- String fname = "test";//Excel文件名
- OutputStream os = response.getOutputStream();//取得输出流
- response.reset();//清空输出流
- response.setHeader("Content-disposition", "attachment; filename=" + fname + ".xls");
- //设定输出文件头
- response.setContentType("application/msexcel");//定义输出类型
- ExcelBean eb = new ExcelBean();
- eb.expordExcel(os);//调用生成excel文件bean
- }catch(Exception e){
- System.out.println(e);
- }
- return mapping.findForward("display");
- }
- }
ExcelBean.java
- package test.whw.upload;
- import java.io.*;
- import jxl.*;
- import jxl.write.*;
- import jxl.format.*;
- import java.util.*;
- import java.awt.Color;
- public class ExcelBean {
- public ExcelBean(){}
- public String expordExcel(OutputStream os)throws Exception{
- jxl.write.WritableWorkbook wbook = Workbook.createWorkbook(os); //建立excel文件
- String tmptitle = "测试文件"; //标题
- jxl.write.WritableSheet wsheet = wbook.createSheet("第一页", 0); //sheet名称
- //设置excel标题
- jxl.write.WritableFont wfont = new jxl.write.WritableFont(
- WritableFont.ARIAL, 16,
- WritableFont.BOLD, false, jxl.format.UnderlineStyle.NO_UNDERLINE,
- jxl.format.Colour.BLACK);
- jxl.write.WritableCellFormat wcfFC = new jxl.write.WritableCellFormat(
- wfont);
- jxl.write.Label wlabel1;
- wlabel1 = new jxl.write.Label(5, 0, tmptitle, wcfFC);
- wsheet.addCell(wlabel1);
- wfont = new jxl.write.WritableFont(
- WritableFont.ARIAL, 14,
- WritableFont.BOLD, false, jxl.format.UnderlineStyle.NO_UNDERLINE,
- jxl.format.Colour.BLACK);
- wcfFC = new jxl.write.WritableCellFormat(
- wfont);
- jxl.write.Label wlabel;
- wlabel = new jxl.write.Label(0, 0, "写入内容");
- wsheet.addCell(wlabel); //
- //合并单元格mergeCells(行,列,行,列);
- wsheet.mergeCells(3,1,5,1);
- wbook.write(); //写入文件
- wbook.close();
- os.close();
- return "success";
- }
- }
struts-config.xml
- <?xml version="1.0" encoding="UTF-8"?>
- <!DOCTYPE struts-config PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 1.1//EN" "http://jakarta.apache.org/struts/dtds/struts-config_1_1.dtd">
- <struts-config>
- <action-mappings>
- <action type="test.whw.upload.DownloadAction" path="/download">
- <forward name="display" path="/display.jsp" />
- </action>
- </action-mappings>
- </struts-config>
- <!--display.jsp是成功的提示页面-->
本文介绍如何使用JXL库在Java环境中读取和写入Excel文件。包括将JXL库集成到项目中、通过输入流读取Excel内容、创建可写的Excel文件并写入数据等步骤。还提供了一个完整的示例,演示如何生成一个包含特定格式和内容的Excel文件。

4428

被折叠的 条评论
为什么被折叠?



