前阵子接到一个项目,其中有个功能就需要把数据填充到 绘制好的EXCEL表单里面,在网上搜集了一些东西之后就开始做了,呵呵。
*********************************************先看看转载的这部分*************************************************************
Java操作Excel之理解JXL--读取Excel 说到如何用JXL读取Excel文件,
现在来看看如何读取Excel模板然后把动态数据写入到模板以生成特定格式的Excel。
同样的思路,先来考虑下会涉及到那些对象,和上篇文章读取相比这里涉及到一个写入的步骤,所以JXL必然会提供一个对象
来支持写入,这就是WritableWorkbook。那么如何得到到这个类的实例,查看APIDoc发现Workbook类提供了几个
静态的createWorkbook方法返回WritableWorkbook实例,可以看到众多createWorkbook方法主要分为两类:一个参数
和两个参数。简单分析可以得知前者仅仅是用来直接生成Excel文件,后者先读取模板再向模板写入数据然后生成Excel。
(还有一个三参数方法加上一个用来设置workbook的参数)
现在按照上篇文章中所讲述的流程来看看读取模板并写入需要那些步骤。
第一步:选择模板文件:
Workbook wb = Workbook.getWorkbook(new File(realpath));
第二步:通过模板得到一个可写的Workbook:
WritableWorkbook wwb = Workbook.createWorkbook(targetFile, wb);
第一个参数是一个输出流对象,比如可以
ByteArrayOutputStream targetFile = new ByteArrayOutputStream();
这样定义这个输出流对象。第二个参数代表了要读取的模板。
第三步:选择模板中名称为StateResult的Sheet:
WritableSheet wws = wwb.getSheet("StateResult");
如果需要也可以创建Sheet
WritableSheet wws = wwb.createSheet("Sheet名称",i);
第四步:选择单元格,写入动态值,根据单元格的不同类型转换成相应类型的单元格:
Label A1 = (Label)wws.getWritableCell(0,0);
A1.setString("单元格内容")
或
Number A2 = (Number)wws.getWritableCell(0,1);//Number是jxl.write.Number
A2.setValue(3.3);
也可以创建新的单元格并且加入到Sheet中
Label C1 = new Label(2,0,"单元格内容");
wws.addCell(C1);
或
Number C1 = new Number(2,0,3.3);
wws.addCell(C1);
在生成Excel报表的时候还会遇到一种需求就是数据的格式问题,我们可能希望数值型单元格以某种格式显示,而字符串型单元格以另
一种格式显示。这些可以通过WritableFont、NumberFormat、WritableCellFormat等实现,下例给单元格A1、A2添加了不同的格式。
java 代码
- WritableFont font= new WritableFont(WritableFont.createFont("宋体"),10,WritableFont.NO_BOLD);
- NumberFormat format = new NumberFormat("###,##0.00");
- WritableCellFormat cellFormat1 = new WritableCellFormat(font,format);
- WritableCellFormat cellFormat2 = new WritableCellFormat(font);
- cellFormat1.setBorder(Border.ALL, jxl.format.BorderLineStyle.THIN);
- cellFormat2.setBorder(Border.ALL, jxl.format.BorderLineStyle.THIN);
- A2.setCellFormat(cellFormat1);
- A1.setCellFormat(cellFormat2);
还有不要忘记关闭WritableWorkbook和Workbook以释放资源:
wwb.close();
wb.close();
最后就可以你需要的方式从输出流targetFile中取得Excel,比如直接生成文件存本地,输出到客户端浏览器等。
如果还有其他需求,按照这种思路,再参照APIDoc相信可以很容易的解决。
至此,Java操作Excel之理解JXL就写完了。
***********************************************************************************************************************************
在这里说说两种表单格式,第一种只需把数据填充就行了,第二种是循环输出数据。
第一种表单如下:
//选择模板文件:
String realpath = "D:/download/test.xls";
try{
Workbook wb = Workbook.getWorkbook(new File(realpath));
//第二步:通过模板得到一个可写的Workbook:第一个参数是一个输出流对象,第二个参数代表了要读取的模板
File targetFile = new File("D:/download/test1.xls");
WritableWorkbook wwb = Workbook.createWorkbook(targetFile, wb);
//第三步:选择模板中名称为StateResult的Sheet:
WritableSheet wws = wwb.getSheet(4);
// 如果需要也可以创建Sheet
// WritableSheet wws = wwb.createSheet("Sheet名称",1);
//第四步:选择单元格,写入动态值,根据单元格的不同类型转换成相应类型的单元格:
//(列,行)
Label A1 = (Label)wws.getWritableCell(0,0);
A1.setString(" 2009年 7 月****出单中心####公司结算表");
WritableFont font= new WritableFont(WritableFont.createFont("宋体"),18,WritableFont.BOLD);
WritableCellFormat cellFormat1 = new WritableCellFormat(font);
cellFormat1.setBorder(Border.ALL, jxl.format.BorderLineStyle.THIN); //Border是jxl.format.Border
cellFormat1.setBackground(Colour.BLUE);//设置单元格背景颜色为天蓝色
cellFormat1.setAlignment(jxl.format.Alignment.CENTRE);//设置文本对其方式,左对齐还是右对齐
A1.setCellFormat(cellFormat1);
Label A2 = (Label)wws.getWritableCell(0,1);
A2.setString("结算日期:2009年 7月7日 至 2009年 7月31日");
WritableFont font2= new WritableFont(WritableFont.createFont("宋体"),12,WritableFont.BOLD);
WritableCellFormat cellFormat2 = new WritableCellFormat(font2);
cellFormat2.setBorder(Border.ALL, jxl.format.BorderLineStyle.THIN); //Border是jxl.format.Border
cellFormat2.setBackground(Colour.BLUE);//设置单元格背景颜色为天蓝色
cellFormat2.setAlignment(jxl.format.Alignment.RIGHT);//设置文本对其方式,左对齐还是右对齐
A2.setCellFormat(cellFormat2);
/********************************public*****************************/
jxl.write.NumberFormat format = new jxl.write.NumberFormat("#");
jxl.write.WritableCellFormat wcf = new jxl.write.WritableCellFormat(format);
WritableFont fonte= new WritableFont(WritableFont.createFont("宋体"),12,WritableFont.NO_BOLD);
WritableCellFormat cellFormat= new WritableCellFormat(fonte,format);
cellFormat.setBorder(Border.ALL, jxl.format.BorderLineStyle.THIN); //Border是jxl.format.Border
cellFormat.setAlignment(jxl.format.Alignment.CENTRE);//设置文本对其方式,左对齐还是右对齐
/********************************public*****************************/
/********************************保单生产明细*****************************/
//份数
jxl.write.Number C4 = new jxl.write.Number(2,3,bean.getPieces(),wcf);
wws.addCell(C4);
C4.setCellFormat(cellFormat);
//保单总印量
jxl.write.Number C5 = new jxl.write.Number(2,4,bean.getAllprintnum(),wcf);
wws.addCell(C5);
C5.setCellFormat(cellFormat);
//.................以此类推
wwb.write();
wwb.close();
wb.close();
}catch(Exception e){
e.printStackTrace();
}
}
第二种表单如下:
循环一个月内 每天的记录,前面是写死的填充数据,现在是循环输出,也很简单,写个FOR循环就OK,关闭WritableWorkbook和Workbook释放资源 要放在FOR循环之外,方法如下:
/**
* 月报表导出EXCEL
*
* 循环输出的地方要采用新建单元格并且加入到Sheet的方式来实现
*
*/
public void reportMonthJXLWriteExcel(List list, List list2)
throws Exception {
// 选择模板文件:
String realpath = "D:/download/test.xls";
try {
Workbook wb = Workbook.getWorkbook(new File(realpath));
// 第二步:通过模板得到一个可写的Workbook:第一个参数是一个输出流对象,第二个参数代表了要读取的模板
File targetFile = new File("D:/download/test1.xls");
WritableWorkbook wwb = Workbook.createWorkbook(targetFile, wb);
// 第三步:选择模板中名称为StateResult的Sheet:
WritableSheet wws = wwb.getSheet(3);
// 第四步:选择单元格,写入动态值,根据单元格的不同类型转换成相应类型的单元格:
// (列,行)
Label A1 = (Label) wws.getWritableCell(0, 0);
A1.setString("2007年07月16日湖南出单中心长沙分公司生产月明细表");
WritableFont font = new WritableFont(WritableFont.createFont("宋体"),
18, WritableFont.BOLD);
WritableCellFormat cellFormat1 = new WritableCellFormat(font);
cellFormat1.setBorder(Border.ALL, jxl.format.BorderLineStyle.THIN); // Border是jxl.format.Border
cellFormat1.setBackground(Colour.BLUE);// 设置单元格背景颜色为天蓝色
cellFormat1.setAlignment(jxl.format.Alignment.CENTRE);// 设置文本对其方式,左对齐还是右对齐
A1.setCellFormat(cellFormat1);
/** ******************************public**************************** */
jxl.write.NumberFormat format = new jxl.write.NumberFormat("#");
jxl.write.WritableCellFormat wcf = new jxl.write.WritableCellFormat(
format);
WritableFont fonte = new WritableFont(
WritableFont.createFont("宋体"), 10, WritableFont.NO_BOLD);
WritableCellFormat cellFormat = new WritableCellFormat(fonte,
format);
cellFormat.setBorder(Border.ALL, jxl.format.BorderLineStyle.THIN); // Border是jxl.format.Border
cellFormat.setAlignment(jxl.format.Alignment.CENTRE);// 设置文本对其方式,左对齐还是右对齐
for (int c = 0; c < 18; c++) {
wws.setColumnView(c, 8);// 给每列设置宽度
}
/** ******************************public**************************** */
int i = 0, j = 0;// i=描述单元格,j=获取JAVA BEAN对象
for (i = 3, j = 0; i < list.size() + 3 && j < list.size(); i++, j++) {
ReportDayBean bean = (ReportDayBean) list.get(j);
Label A4 = new Label(0, i, bean.getBusitime());
wws.addCell(A4);
WritableFont font2 = new WritableFont(WritableFont
.createFont("宋体"), 10, WritableFont.NO_BOLD);
WritableCellFormat cellFormat2 = new WritableCellFormat(font2);
cellFormat2.setBorder(Border.ALL,
jxl.format.BorderLineStyle.THIN); // Border是jxl.format.Border
cellFormat2.setAlignment(jxl.format.Alignment.CENTRE);// 设置文本对其方式,左对齐还是右对齐
A4.setCellFormat(cellFormat2);
// 份数
jxl.write.Number B4 = new jxl.write.Number(1, i, bean
.getPieces(), wcf);
wws.addCell(B4);
B4.setCellFormat(cellFormat);
// 总印量
jxl.write.Number C4 = new jxl.write.Number(2, i, bean
.getAllprintnum(), wcf);
wws.addCell(C4);
C4.setCellFormat(cellFormat);
// 超印量
jxl.write.Number D4 = new jxl.write.Number(3, i, bean
.getOverprintnum(), wcf);
wws.addCell(D4);
D4.setCellFormat(cellFormat);
// 清单印量
jxl.write.Number E4 = new jxl.write.Number(4, i, bean
.getListprintnum(), wcf);
wws.addCell(E4);
E4.setCellFormat(cellFormat);
// A4纸
jxl.write.Number F4 = new jxl.write.Number(5, i, bean
.getPaper(), wcf);
wws.addCell(F4);
F4.setCellFormat(cellFormat);
// 份数
jxl.write.Number G4 = new jxl.write.Number(6, i, bean
.getZ_pieces(), wcf);
wws.addCell(G4);
G4.setCellFormat(cellFormat);
// 印量
jxl.write.Number H4 = new jxl.write.Number(7, i, bean
.getZ_printnum(), wcf);
wws.addCell(H4);
H4.setCellFormat(cellFormat);
// 用纸
jxl.write.Number I4 = new jxl.write.Number(8, i, bean
.getZ_paper(), wcf);
wws.addCell(I4);
I4.setCellFormat(cellFormat);
// 本埠信函
jxl.write.Number J4 = new jxl.write.Number(9, i, bean
.getLocal(), wcf);
wws.addCell(J4);
J4.setCellFormat(cellFormat);
// 外埠信函
jxl.write.Number K4 = new jxl.write.Number(10, i, bean
.getForeign(), wcf);
wws.addCell(K4);
K4.setCellFormat(cellFormat);
// 印量
jxl.write.Number L4 = new jxl.write.Number(11, i, bean
.getPrintnum(), wcf);
wws.addCell(L4);
L4.setCellFormat(cellFormat);
// 预印用纸
jxl.write.Number M4 = new jxl.write.Number(12, i, bean
.getPrepaper(), wcf);
wws.addCell(M4);
M4.setCellFormat(cellFormat);
// 空白用纸
jxl.write.Number N4 = new jxl.write.Number(13, i, bean
.getBlankpaper(), wcf);
wws.addCell(N4);
N4.setCellFormat(cellFormat);
// 信封
jxl.write.Number O4 = new jxl.write.Number(14, i, bean
.getEnvelope(), wcf);
wws.addCell(O4);
O4.setCellFormat(cellFormat);
// 装订份数
jxl.write.Number P4 = new jxl.write.Number(15, i, bean
.getQ_pieces(), wcf);
wws.addCell(P4);
P4.setCellFormat(cellFormat);
// 印量
jxl.write.Number Q4 = new jxl.write.Number(16, i, bean
.getQ_printnum(), wcf);
wws.addCell(Q4);
Q4.setCellFormat(cellFormat);
// A4纸
jxl.write.Number R4 = new jxl.write.Number(17, i, bean
.getQ_paper(), wcf);
wws.addCell(R4);
R4.setCellFormat(cellFormat);
}
System.out.println("iiiiiiiiiiii=" + i);
ReportDayBean bean = (ReportDayBean) list2.get(0);
Label A4 = new Label(0, i, "小计");
wws.addCell(A4);
WritableFont font2 = new WritableFont(
WritableFont.createFont("宋体"), 12, WritableFont.NO_BOLD);
WritableCellFormat cellFormat2 = new WritableCellFormat(font2);
cellFormat2.setBorder(Border.ALL, jxl.format.BorderLineStyle.THIN); // Border是jxl.format.Border
cellFormat2.setAlignment(jxl.format.Alignment.CENTRE);// 设置文本对其方式,左对齐还是右对齐
A4.setCellFormat(cellFormat2);
// 份数
jxl.write.Number B4 = new jxl.write.Number(1, i, bean.getPieces(),
wcf);
wws.addCell(B4);
B4.setCellFormat(cellFormat);
// 总印量
jxl.write.Number C4 = new jxl.write.Number(2, i, bean
.getAllprintnum(), wcf);
wws.addCell(C4);
C4.setCellFormat(cellFormat);
// 超印量
jxl.write.Number D4 = new jxl.write.Number(3, i, bean
.getOverprintnum(), wcf);
wws.addCell(D4);
D4.setCellFormat(cellFormat);
// 清单印量
jxl.write.Number E4 = new jxl.write.Number(4, i, bean
.getListprintnum(), wcf);
wws.addCell(E4);
E4.setCellFormat(cellFormat);
// A4纸
jxl.write.Number F4 = new jxl.write.Number(5, i, bean.getPaper(),
wcf);
wws.addCell(F4);
F4.setCellFormat(cellFormat);
// 份数
jxl.write.Number G4 = new jxl.write.Number(6, i,
bean.getZ_pieces(), wcf);
wws.addCell(G4);
G4.setCellFormat(cellFormat);
// 印量
jxl.write.Number H4 = new jxl.write.Number(7, i, bean
.getZ_printnum(), wcf);
wws.addCell(H4);
H4.setCellFormat(cellFormat);
// 用纸
jxl.write.Number I4 = new jxl.write.Number(8, i, bean.getZ_paper(),
wcf);
wws.addCell(I4);
I4.setCellFormat(cellFormat);
// 本埠信函
jxl.write.Number J4 = new jxl.write.Number(9, i, bean.getLocal(),
wcf);
wws.addCell(J4);
J4.setCellFormat(cellFormat);
// 外埠信函
jxl.write.Number K4 = new jxl.write.Number(10, i,
bean.getForeign(), wcf);
wws.addCell(K4);
K4.setCellFormat(cellFormat);
// 印量
jxl.write.Number L4 = new jxl.write.Number(11, i, bean
.getPrintnum(), wcf);
wws.addCell(L4);
L4.setCellFormat(cellFormat);
// 预印用纸
jxl.write.Number M4 = new jxl.write.Number(12, i, bean
.getPrepaper(), wcf);
wws.addCell(M4);
M4.setCellFormat(cellFormat);
// 空白用纸
jxl.write.Number N4 = new jxl.write.Number(13, i, bean
.getBlankpaper(), wcf);
wws.addCell(N4);
N4.setCellFormat(cellFormat);
// 信封
jxl.write.Number O4 = new jxl.write.Number(14, i, bean
.getEnvelope(), wcf);
wws.addCell(O4);
O4.setCellFormat(cellFormat);
// 装订份数
jxl.write.Number P4 = new jxl.write.Number(15, i, bean
.getQ_pieces(), wcf);
wws.addCell(P4);
P4.setCellFormat(cellFormat);
// 印量
jxl.write.Number Q4 = new jxl.write.Number(16, i, bean
.getQ_printnum(), wcf);
wws.addCell(Q4);
Q4.setCellFormat(cellFormat);
// A4纸
jxl.write.Number R4 = new jxl.write.Number(17, i,
bean.getQ_paper(), wcf);
wws.addCell(R4);
R4.setCellFormat(cellFormat);
int k = i + 2;// 这里是空一行再写入制表人,审核人......
wws.mergeCells(4, k, 17, k);
Label E14 = new Label(
4,
k,
"制表人: 审核人: 机构负责人: 机构财务部负责人: ");
wws.addCell(E14);
WritableCellFormat cellFormatinfo = new WritableCellFormat(font2);
cellFormatinfo.setBorder(Border.ALL,
jxl.format.BorderLineStyle.NONE); // Border是jxl.format.Border
cellFormatinfo.setAlignment(jxl.format.Alignment.LEFT);// 设置文本对其方式,左对齐还是右对齐
E14.setCellFormat(cellFormatinfo);
wwb.write();
wwb.close();
wb.close();
} catch (Exception e) {
}
}
分享到:
相关推荐
Java 操作 Excel 之 JXL 是一个非常实用的库,用于在 Java 应用程序中创建、读取和修改 Microsoft Excel 文件。JXL 提供了一系列的 API,使得开发者能够方便地处理 Excel 数据,无论是简单的数据读写,还是复杂的...
总结来说,利用Java和jxl库,我们可以轻松地创建自定义Excel模板,满足各种复杂的格式需求,并且能方便地在客户端保存或在线打开。通过深入理解和熟练运用jxl提供的API,开发者可以构建出强大而灵活的Excel生成工具...
描述中提到的"采用类似EL表达式的方式生成模版",意味着在使用jxl时,可以利用类似于Expression Language(EL)的语法来动态地填充Excel模板。EL是JavaServer Pages (JSP)中的一种轻量级、简洁的表达式语言,用于...
标题 "JXL根据模板文件,生成新文件,填充excel" 提到的是使用JXL库来创建Excel文件并根据模板填充数据。JXL是一个Java库,它允许开发人员读写Microsoft Excel文件,为处理电子表格数据提供了便利。在这个场景中,...
在Java编程环境中,导出数据到Excel是一种常见的需求,特别是在数据分析、报表生成或者数据交换的场景下。...通过对这个示例的分析和学习,你应该能更好地理解如何在实际项目中运用JXL库进行Excel模板导出。
首先,你需要创建一个Excel模板文件,这个模板包含你想要在生成的Excel中展示的数据结构和样式。在模板中,你可以预定义单元格的格式,如字体、颜色、边框等,同时可以使用占位符来表示将要填充的数据。 **步骤2:...
在Java编程环境中,我们经常需要处理数据的导入和导出,其中Excel文件是最常见的格式之一。本示例将介绍如何使用Java创建Excel文件并写入数据,主要涉及的库是`jxl`,这是一个用于读写Excel文件的开源Java库。 首先...
- **报表自动生成**:可以自动从数据库或其他数据源提取数据,填充到Excel模板中,生成报告。 - **数据分析**:对于需要大量数据处理和分析的应用,可以直接在Java程序中操作Excel文件进行数据处理。 - **数据导出**...
2. 报表生成:使用Java可以根据模板生成报表,自动将数据填充到报表中。 3. 文件自动化处理:使用Java可以自动处理大量的Excel文件,例如批量修改文件名、批量导出数据等。 Java操作Excel文件的技术难点: 1. ...
此方法从一个现有的Excel模板文件开始,计划加载数据到工作表中。虽然具体的实现细节没有给出,但可以预见,接下来的步骤会涉及遍历`dataList`并将数据写入工作表的相应单元格。 #### 总结 通过上述分析,我们可以...
本文将详细讨论如何使用JXL库创建一个通用的工具类来读取Excel模板并填充数据。 首先,我们需要了解JXL库的基本用法。JXL库提供了多种API,可以用来操作Excel文件的各个部分,包括工作簿(Workbook)、工作表...
jxl库是一个广泛使用的开源库,它允许开发者用Java读取、写入和修改Excel文件。本篇文章将深入探讨如何使用jxl库来实现数据从数据库导出到Excel的过程。 首先,要使用jxl库,你需要将其添加到项目的类路径中。如果...
Struts2是一个流行的Java web框架,它为开发者提供了一种结构化的方式来构建应用程序,而JXL则是一个Java库,用于读取、写入和修改Excel电子表格文件。这篇博客文章结合了这两个技术,展示了如何在Struts2应用中生成...
JXLS则采用模板的方式操作Excel,它允许开发者创建一个Excel模板,然后根据数据动态填充模板,生成最终的Excel文件。这种方式适用于需要批量生成格式统一的Excel报告的情况。使用JXLS的基本流程包括: 1. 创建Excel...
提供的Excel模板可能包含了预定义的格式、样式和数据结构,用户可以按照模板填写数据,方便统一和规范数据输入。在程序中,可以通过读取模板,填充用户输入的数据,然后将整个工作簿保存,从而实现数据的批量导入。...
### 如何用Java输出Excel文件:使用jxl库详解 在Java编程中,处理Excel文件是一种常见的需求,尤其是在企业级应用中,数据导出至Excel是数据报告、数据分析的重要环节。jxl(Java eXcel API)是一个强大的库,允许...
5. **写入类操作**:另一个类可能是用于写入Excel文件的,它可能接受用户提供的数据,然后利用JXL库创建新的工作簿,添加工作表,填充数据到指定的单元格。在描述中提到的`blank.xls`就是一个空白模板文件,写入类...
在这个过程中,压缩包中的"excel导出jxl"可能包含了一个示例程序或者模板,帮助开发者理解如何实现上述步骤。通过查看和运行这些代码,你可以更深入地了解如何将数据库数据导出到Excel文件中。 总之,使用JXL库在...
JXL库是Java中用于处理Excel文件的一个流行选择,它提供了读取、写入和修改Excel文件的功能。本篇文章将深入探讨如何使用JXL库实现Excel的导入导出,并通过反射原理进行动态内容验证。 首先,我们需要了解JXL库的...