package com;

import java.io.BufferedOutputStream;
import java.io.File;
import java.io.IOException;
import java.io.OutputStream;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.util.ArrayList;
import java.util.List; import javax.servlet.http.HttpServletResponse; import jxl.Workbook;
import jxl.WorkbookSettings;
import jxl.format.Alignment;
import jxl.format.Border;
import jxl.format.BorderLineStyle;
import jxl.format.Colour;
import jxl.format.UnderlineStyle;
import jxl.write.Label;
import jxl.write.Number;
import jxl.write.WritableCell;
import jxl.write.WritableCellFormat;
import jxl.write.WritableFont;
import jxl.write.WritableFont.FontName;
import jxl.write.WritableSheet;
import jxl.write.WritableWorkbook;
import jxl.write.WriteException;
import jxl.write.biff.RowsExceededException; public class ExcelUtil {
private static String defaultEncoding = "gbk"; /**
* 1创建工作簿,用于response的输出流返回
* @param response HttpServletResponse
* @param fileName 文件名
* @return
*/
public static WritableWorkbook createWorkBook(HttpServletResponse response,String fileName){ OutputStream os = null;
BufferedOutputStream bos = null;
WritableWorkbook wwb = null;
try {
os = response.getOutputStream();
response.setContentType("application/vnd.ms-excel");
response.setHeader("Content-Disposition", "attachment; filename=".concat(fileName)); bos = new BufferedOutputStream(os);
wwb = createWorkBook(bos); } catch (IOException e) {
e.printStackTrace();
} finally{
try {
if(bos!=null){
bos.flush();
bos.close();
bos = null;
}
if(os!=null){
os.close();
os = null;
}
} catch (IOException e) {
e.printStackTrace();
}
} return wwb;
} /**
* 1创建工作簿,用于导出文件到某个路径
* @param exportPath
* @return
*/
public static WritableWorkbook createWorkBook(String exportPath){
File file = new File(exportPath);
if(!file.exists()||file.isDirectory()){
try {
file.createNewFile();
} catch (IOException e) {
e.printStackTrace();
}
} WritableWorkbook wwb = createWorkBook(file);
return wwb;
} /**
* 创建WritableWorkbook
* @param obj
* @return
*/
private static WritableWorkbook createWorkBook(Object obj){
if(obj==null){
return null;
} System.out.println("创建工作簿WritableWorkbook开始..."); WorkbookSettings setting = new WorkbookSettings();
setting.setEncoding(defaultEncoding); WritableWorkbook wwb = null;
try { if(obj instanceof File){
File file = (File)obj;
wwb = Workbook.createWorkbook(file,setting);
}else if(obj instanceof BufferedOutputStream){
BufferedOutputStream bos = (BufferedOutputStream)obj;
wwb = Workbook.createWorkbook(bos,setting);
} } catch (IOException e) {
e.printStackTrace();
} System.out.println("创建工作簿WritableWorkbook结束..."); return wwb;
} /**
* 根据SheetNames数量创建对应数量的sheet
* @param sheetNames
* @param wwb
* @return
*/
public static List<WritableSheet> createSheet(String[] sheetNames,WritableWorkbook wwb){
if(sheetNames==null||sheetNames.length==0){
return null;
}
if(wwb==null){
return null;
}
int sheetNum = sheetNames.length;
System.out.println("Excel创建sheet数量:"+sheetNum); List<WritableSheet> list = new ArrayList<WritableSheet>(sheetNum); for(int i= 0; i<sheetNum ; i++){
WritableSheet ws = wwb.createSheet(sheetNames[i], i);
list.add(ws);
} return list; } /**
* 创建title格式
* @return
*/
public static WritableCellFormat getTitleFormat(){ System.out.println("创建title格式..."); FontName fontName = WritableFont.createFont("宋体");
int fontSize = 15;
boolean isItalic = false;//是否斜体 //参数依次是:字体设置/字体大小/字体粗细/是否是斜体/下划线类型/颜色
WritableFont titleFont = new WritableFont(fontName, fontSize, WritableFont.BOLD, isItalic, UnderlineStyle.NO_UNDERLINE, Colour.BLACK);
WritableCellFormat titleFormat = new WritableCellFormat(titleFont); return titleFormat;
} /**
* 获取内容格式
* @return
*/
public static WritableCellFormat getContentFormat(){ System.out.println("创建内容格式..."); WritableCellFormat contentFormat = new WritableCellFormat();
try {
contentFormat.setWrap(true);//是否换行
contentFormat.setBorder(Border.ALL, BorderLineStyle.THIN, Colour.BLACK);//全框/细线/黑色
contentFormat.setAlignment(Alignment.LEFT);//水平居左
} catch (WriteException e) {
e.printStackTrace();
} return contentFormat;
} /**
* 单元格插入内容
* @param sheet 表单对象
* @param columnIndex 列
* @param rowIndex 行
* @param content 内容
* @param format 格式
*/
public static void addCell(WritableSheet sheet,int columnIndex,int rowIndex,Object content,WritableCellFormat format){ WritableCell cell = null; if(content instanceof Double){
if(format!=null){
cell = new Number(columnIndex, rowIndex, (Double)content, format);
}else{
cell = new Number(columnIndex, rowIndex, (Double)content);
} }else{
if(content==null){
content = "";
}
if(format!=null){
cell = new Label(columnIndex, rowIndex, (String)content, format);
}else{
cell = new Label(columnIndex, rowIndex, (String)content);
}
} try {
sheet.addCell(cell);
} catch (RowsExceededException e) {
e.printStackTrace();
} catch (WriteException e) {
e.printStackTrace();
}
} /**
* 解析一个list对象插入到sheet
* @param sheet
* @param list
* @param titles 列名 空列填""
* @param clazzFields class类的属性名:"getXXX"格式 空列填""
*/
public static void parseClass(WritableSheet sheet,List list,String[] titles,String[] clazzFields){
if(sheet==null||list==null||titles==null||clazzFields==null){
return;
} WritableCellFormat format = getContentFormat(); int rowIndex = 1;//默认第一行还有个大标题~,如果不需要那个大标题,此处改成0
//先将列名插入sheet
for(int columnIndex=0;columnIndex<titles.length;columnIndex++){
addCell(sheet, columnIndex, rowIndex, titles[columnIndex], format);
} rowIndex++; System.out.println("遍历传入的list对象,并写入sheet表单开始...");
for(int i=0;i<list.size();i++){ int startColumn = 0;
if("序号".equals(titles[0])){
addCell(sheet, startColumn, rowIndex, (i+1)+"", format);
startColumn++;
}
Object obj = list.get(i);
//将传入的clazzFields从clazz取出来
for(int columnIndex=startColumn;columnIndex<clazzFields.length;columnIndex++){ if("".equals(clazzFields[columnIndex])){//如果属性没写,默认填一空行
addCell(sheet, columnIndex, rowIndex, "", format);
continue;
} //属性不为空,反射出类的属性,取值
try {
Method method = obj.getClass().getDeclaredMethod(clazzFields[columnIndex], null);
Object field = method.invoke(obj, null);
// Class returnType = method.getReturnType();
addCell(sheet, columnIndex, rowIndex, field, format); } catch (SecurityException e) {
e.printStackTrace();
} catch (NoSuchMethodException e) {
e.printStackTrace();
} catch (IllegalArgumentException e) {
e.printStackTrace();
} catch (IllegalAccessException e) {
e.printStackTrace();
} catch (InvocationTargetException e) {
e.printStackTrace();
}
} rowIndex++;
} System.out.println("遍历传入的list对象,并写入sheet表单结束..."); } public static void main(String[] args) {
//模拟数据
List<TestClass> testList = new ArrayList<TestClass>();
double num = 1000d;
for(int i=0;i<6;i++){
TestClass t = new TestClass();
t.setA("testA"+i);
t.setB("testB"+i);
t.setC(num-i); testList.add(t);
} //导出开始
WritableWorkbook wwb = null;
try {
wwb = createWorkBook("D:\\测试1121.xls");
String[] names = {"张三","李四"};
List<WritableSheet> sheets = createSheet(names, wwb); WritableCellFormat titleFormat = getTitleFormat();
WritableCellFormat contentFormat = getContentFormat(); for(WritableSheet sheet :sheets){ addCell(sheet, 0, 0, "大标题123123654654", titleFormat); String[] titles = {"序号","","A","C","B"};
String[] methods = {"","","getA","getC","getB"};
parseClass(sheet, testList, titles, methods); addCell(sheet, 3, testList.size()+3, "审核:", null); } wwb.write();
} catch (IOException e) {
e.printStackTrace();
} finally{
if(wwb!=null){
try {
wwb.close();
wwb = null;
} catch (WriteException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
} }
//结束 }
}

测试类:

package com;

public class TestClass {
private String a;
private String b;
private Double c; public TestClass(){ } public String getA() {
return a;
} public void setA(String a) {
this.a = a;
} public String getB() {
return b;
} public void setB(String b) {
this.b = b;
} public Double getC() {
return c;
} public void setC(Double c) {
this.c = c;
} }

自己写的java用jxl导出到excel工具的更多相关文章

  1. JAVA利用JXL导出/生成 EXCEL

    /** * 导出导出采暖市场部收入.成本.利润明细表 * @author JIA-G-Y */ public String exporExcel(String str) { String str=Se ...

  2. java利用JXL导出/生成 EXCEL【my】

    一.创建一个excel文件 package test;// 生成Excel的类 import java.io.File; import jxl.Workbook;import jxl.write.La ...

  3. Java中用JXL导出Excel代码详解

    jxl是一个韩国人写的java操作excel的工具, 在开源世界中,有两套比较有影响的API可供使用,一个是POI,一个是jExcelAPI.其中功能相对POI比较弱一点.但jExcelAPI对中文支 ...

  4. JAVA利用JXL导出 EXCEL (在原有的excel模板上把数据导到excel上)

    添加依赖 <dependency> <groupId>net.sourceforge.jexcelapi</groupId> <artifactId>j ...

  5. JAVA利用JXL导出/生成 EXCEL1

    /** * 导出导出采暖市场部收入.成本.利润明细表 * @author JIA-G-Y */ public String exporExcel(String str) { String str=Se ...

  6. JXL 读取 Excel java中jxl导出数据到excel的例子 上传文件

    2010-10-14 19:17:06 com.opensymphony.xwork2.util.logging.commons.CommonsLogger info 信息: Entferne Dat ...

  7. java使用jxl,poi解析excel文件

    public interface JavaExcel { /** * 使用jxl写excel文件 */ public void writeJxlExcel(); /** * 使用jxl读excel文件 ...

  8. java的jxl技术导入Excel

    项目结构: http://www.cnblogs.com/hongten/gallery/image/112177.html 在项目中我们看到Reference Libraries中的jxl.jar包 ...

  9. java 使用jxl poi 操作excel

    java操作excel  创建.修改 xls 文件 JAVA操作Excel文件 Java生成和操作Excel文件 java导出Excel通用方法 Java 实现导出excel表 POI Java PO ...

随机推荐

  1. HttpClient模拟http请求

    Http协议的重要性相信不用我多说了,HttpClient相比传统JDK自带的URLConnection,增加了易用性和灵活性(具体区别,日后我们再讨论),它不仅是客户端发送Http请求变得容易,而且 ...

  2. BizTalk开发系列(十一) 在Orchestration中执行Pipeline

    由于开发需要有时要在流程中执行Pipeline.比如从DB的某个字段中取消息的字符串并在流程中构造消息.该需要通过pipeline进行升级 属性字段,验证消息等处理.BizTalk架构已经开放了此接口 ...

  3. cookie案例-显示用户上次访问网站的时间

    package cn.itcast.cookie; import java.io.IOException; import java.io.PrintWriter; import java.util.D ...

  4. app与后台通信协议

    通用的语言有很多种,例如英语和中文,在网络的通讯中,通用的协议有很多,其中http是被最广泛使用的.如果是私有的协议,那就只能自己设计了. 用http是最方便的,如果是私有协议,包含协议的封装和拆解, ...

  5. iOS 3D touch 使用技巧

    第一个 在桌面中3d Touch 打开菜单 由于本人纯属代码党,本次实现方法也只使用代码实现 到达到这个效果并不难,只需要在appdelegate中实现以下代码即可 ,当然也有缺点,就是这个app没运 ...

  6. zepto源码--核心方法7(管理包装集)--学习笔记

    后面应该会有几篇连续介绍关于zepto包装集的文章.涉及的函数较多,就分别介绍,今天介绍几个使用关系获取包装集的方法.prev, next, first, last, siblings, eq pre ...

  7. form submit时将__VIEWSTATE和__VIEWSTATEGENERATOR一起post到另外的页面,出现验证视图状态 MAC 失败。

    错误信息: 验证视图状态 MAC 失败.如果此应用程序由网络场或群集承载,请确保 配置指定了相同的 validationKey 和验证算法.不能在群集中使用 AutoGenerate. 原因分析: F ...

  8. 集合Hashtable Dictionary Hashset

    #region Dictionary<K,V> Dictionary<string, Person> dict = new Dictionary<string, Pers ...

  9. Python2.7的安装

    >登录python官网下载python2.7的相关版本 python官网链接 >根据平台选择相应的版本 >下载完毕后点击安装即可 >配置环境变量 >安装成功

  10. CSS3 中border-image详解

    CSS3 border-image详解.应用及jQuery插件 一.border-image的兼容性 border-image可以说是CSS3中的一员大将,将来一定会大放光彩,其应用潜力真的是非常的惊 ...