打印系列 —— 利用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文件中的单元格
代码:
- <%@ page contentType="text/html; charset=gb2312" %>
- <%@ page import="java.io.*,jxl.*,jxl.write.*,jxl.write.*,jxl.format.*" %>
- String path="c://excel.xls";//Excel文件URL
- InputStream is = new FileInputStream(path);//写入到FileInputStream
- jxl.Workbook wb = Workbook.getWorkbook(is); //得到工作薄
- jxl.Sheet st = wb.getSheet(0);//得到工作薄中的第一个工作表
- Cell cell=st.getCell(0,0);//得到工作表的第一个单元格,即A1
- String content=cell.getContents();//getContents()将Cell中的字符转为字符串
- wb.close();//关闭工作薄
- 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位置及内容.
代码:
- <%@ 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" οnclick="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生成Excel相关推荐
- 利用owc生成excel并且显示在页面
主要利用OWC生成Excel,画表头和显示从数据库读出来的数据,然后显示在前台页面上,无需客户端安装office,只需要安装owc.一年以前写的,似乎很烦锁,哪位有高见请指教! 后面利用OWC操作EX ...
- java的json导出excel_利用json生成excel表格
起因: 之前利用反射生成excel导出,这个组件本来挺好用的,结果,坑爹的本地研发没有问题,生产环境却有问题.不知道什么原因直接导致服务重启,还重新加载类,直接导致jvm的永久区内存溢出. 异常: j ...
- JXL生成Excel,并提供下载(2:提供下载)
实现效果: 项目中使用JXL生成Excel,使生成的Excel可以让用户下载,如下图 一.生成Excel 二.提供下载 实现思路: 1.页面使用form表单提交方式(Ajax提交方式,我这里不行) 2 ...
- java使用jxl生成excel表格,jsp使用js下载excel文件xls
java使用jxl生成excel表格,jsp使用js下载excel文件 后端代码 maven jar包 主体代码逻辑 引入的jar包 具体代码段 重点详解 表头和表格内容两种格式 直接将 HttpSe ...
- JXL生成EXCEL时单元格设置为数值却展示货币或自定义的问题处理
前言: 以下内容为个人见解,勿喷,欢迎有更好解决方法的大佬指点 问题起源: 最近项目中有一个这样的需求:根据后台数据生成Excel后转存到服务器上供用户进行下载.这本来是一个比较常见的需求,不存在什么 ...
- 利用POI生成EXCEL报表(通过web页面导出后台数据)
很多时候需要将数据利用浏览器进行导出,这个时候我们就可以采用Apache的POI进行实现通过web页面实现Excel导出后台数据,并且以.xlsx的形式下载到本地,也就是excel表格形式. 首先先下 ...
- Java利用POI生成Excel强制换行
前一段时间在做一个学校排课系统时,有一个地方需要利用把课程表生成excel汇出给客户,由于之前用excel都只是简单的应用,在单元格里都是用自动换行,而这次可能需要用到手动强制换行. 于是我在网上找 ...
- poi jxl 生成EXCEL 报表
http://www.iteye.com/topic/611329 前2天后台系统需要生成报表,正好抽时间复习了一下之前做过的JAVA生成EXCEL,下面介绍POI 和JXL 生成报表的2种方式. 1 ...
- 利用poi生成excel考勤表
今天利用了Apache poi 编写了一个生成excel的考勤表,Apache poi链接地址为http://poi.apache.org/,代码如下: package com.pom;import ...
最新文章
- 【SCOI 2008】奖励关
- ubuntu root默认密码(初始密码)
- 《AngularJS实战》——3.1 模板中的过滤器
- Socket经验记录
- 每3位新码农中就有2个是单身?来自31000人的调查报告显示……
- 安装Exchange Server 2013
- mysql 几个外键类型_mysql – 选择每个外键类型的最高记录
- String、StringBuffer、StringBuilder三者的区别
- 第二季-专题0-课程规划
- 用React加CSS3实现微信拆红包动画
- 从遥感影像到土地利用转移矩阵
- 微信公众号 | 适合程序员的公众号排版
- [转载]Geronimo 叛逆者,第 8 部分: 未来的 Apache Geronimo
- 员工接私单可不可以追究刑事责任
- Android N 程序适配要点
- arctanx麦克劳林公式推导过程_三角函数的求导过程
- autojs自定义Switch
- 终极解决Excel科学计数、日期变#号等问题
- 清空 通讯录 android,安卓 通讯录 清除数据恢复
- 力扣刷题全局变量WA,局部变量AC的问题
热门文章
- Axisfault faultcode:Server.userException异常
- 网络流行伤感日志:如果有一天,我从你的世界消失了
- php判断mysql表的字段_tp6 获取数据库某个表的所有字段名称_php菜鸟技术天地-CSDN博客...
- webpack抽离css,压缩css代码 和 js代码
- 星际官方小说《刀锋女王》——第4章
- 2019年区块链教育培训课程研究报告 |链塔智库
- 高精度定位系统:地铁隧道人员定位智能巡检
- 华为开发者大会2023(Cloud)之旅
- 铁匠smith_铁匠中的独特角色阴影
- 微信小程序|基于小程序+C#制作一个聊天系统