- 浏览: 44690 次
最新评论
创建Excel的工具类 ExcelUtil
package com.joyveb.genlotwbos.util;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.text.DateFormat;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFCellStyle;
import org.apache.poi.hssf.usermodel.HSSFFont;
import org.apache.poi.hssf.usermodel.HSSFPrintSetup;
import org.apache.poi.hssf.usermodel.HSSFRichTextString;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.hssf.util.HSSFCellUtil;
import org.apache.poi.ss.usermodel.CellStyle;
import org.apache.poi.ss.usermodel.Font;
import org.apache.poi.ss.util.CellRangeAddress;
import com.lottery.genlotwbos.domain.StatByDrawNumber;
import com.lottery.genlotwbos.domain.GxStatByDrawNumber;
/**
* 描述:Excel写操作帮助类
*
* @author ALEX
* @since 2010-11-24
* @version 1.0v
*/
public class ExcelUtil {
/**
* 功能:将HSSFWorkbook写入Excel文件
*
* @param wb
* HSSFWorkbook
* @param absPath
* 写入文件的相对路径
* @param wbName
* 文件名
*/
public static void writeWorkbook(HSSFWorkbook wb, String fileName) {
FileOutputStream fos = null;
try {
fos = new FileOutputStream(fileName);
wb.write(fos);
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} finally {
try {
if (fos != null) {
fos.close();
}
} catch (IOException e) {
e.printStackTrace();
}
}
}
/**
* 功能:创建HSSFSheet工作簿
*
* @param wb
* HSSFWorkbook
* @param sheetName
* String
* @return HSSFSheet
*/
public static HSSFSheet createSheet(HSSFWorkbook wb, String sheetName) {
HSSFSheet sheet = wb.createSheet(sheetName);
sheet.setDefaultColumnWidth(12);
sheet.setGridsPrinted(false);
sheet.setDisplayGridlines(false);
return sheet;
}
/**
* 功能:创建HSSFRow
*
* @param sheet
* HSSFSheet
* @param rowNum
* int
* @param height
* int
* @return HSSFRow
*/
public static HSSFRow createRow(HSSFSheet sheet, int rowNum, int height) {
HSSFRow row = sheet.createRow(rowNum);
row.setHeight((short) height);
return row;
}
/**
* 功能:创建CellStyle样式
*
* @param wb
* HSSFWorkbook
* @param backgroundColor
* 背景色
* @param foregroundColor
* 前置色
* @param font
* 字体
* @return CellStyle
*/
public static CellStyle createCellStyle(HSSFWorkbook wb,
short backgroundColor, short foregroundColor, short halign,
Font font) {
CellStyle cs = wb.createCellStyle();
cs.setAlignment(halign);
cs.setVerticalAlignment(CellStyle.VERTICAL_CENTER);
cs.setFillBackgroundColor(backgroundColor);
cs.setFillForegroundColor(foregroundColor);
cs.setFillPattern(CellStyle.SOLID_FOREGROUND);
cs.setFont(font);
return cs;
}
/**
* 功能:创建带边框的CellStyle样式
*
* @param wb
* HSSFWorkbook
* @param backgroundColor
* 背景色
* @param foregroundColor
* 前置色
* @param font
* 字体
* @return CellStyle
*/
public static CellStyle createBorderCellStyle(HSSFWorkbook wb,
short backgroundColor, short foregroundColor, short halign,
Font font) {
CellStyle cs = wb.createCellStyle();
cs.setAlignment(halign);
cs.setVerticalAlignment(CellStyle.VERTICAL_CENTER);
cs.setFillBackgroundColor(backgroundColor);
cs.setFillForegroundColor(foregroundColor);
cs.setFillPattern(CellStyle.SOLID_FOREGROUND);
cs.setFont(font);
cs.setBorderLeft(CellStyle.BORDER_DASHED);
cs.setBorderRight(CellStyle.BORDER_DASHED);
cs.setBorderTop(CellStyle.BORDER_DASHED);
cs.setBorderBottom(CellStyle.BORDER_DASHED);
return cs;
}
/**
* 功能:创建CELL
*
* @param row
* HSSFRow
* @param cellNum
* int
* @param style
* HSSFStyle
* @return HSSFCell
*/
public static HSSFCell createCell(HSSFRow row, int cellNum, CellStyle style) {
HSSFCell cell = row.createCell(cellNum);
cell.setCellStyle(style);
return cell;
}
/**
* 功能:合并单元格
*
* @param sheet
* HSSFSheet
* @param firstRow
* int
* @param lastRow
* int
* @param firstColumn
* int
* @param lastColumn
* int
* @return int 合并区域号码
*/
public static int mergeCell(HSSFSheet sheet, int firstRow, int lastRow,
int firstColumn, int lastColumn) {
return sheet.addMergedRegion(new CellRangeAddress(firstRow, lastRow,
firstColumn, lastColumn));
}
/**
* 功能:创建字体
*
* @param wb
* HSSFWorkbook
* @param boldweight
* short
* @param color
* short
* @return Font
*/
public static Font createFont(HSSFWorkbook wb, short boldweight,
short color, short size) {
Font font = wb.createFont();
font.setBoldweight(boldweight);
font.setColor(color);
font.setFontHeightInPoints(size);
return font;
}
/**
* 设置合并单元格的边框样式
*
* @param sheet
* HSSFSheet
* @param ca
* CellRangAddress
* @param style
* CellStyle
*/
public static void setRegionStyle(HSSFSheet sheet, CellRangeAddress ca,
CellStyle style) {
for (int i = ca.getFirstRow(); i <= ca.getLastRow(); i++) {
HSSFRow row = HSSFCellUtil.getRow(i, sheet);
for (int j = ca.getFirstColumn(); j <= ca.getLastColumn(); j++) {
HSSFCell cell = HSSFCellUtil.getCell(row, j);
cell.setCellStyle(style);
}
}
}
public static String RMBMoney(Long value) {
String strValue = value + "";
char[] arrayValue = strValue.toCharArray();
for (int i = arrayValue.length - 1; i >= 0; i--) {
}
return "¥";
}
/**
* 设置合并单元格的边框样式
*
* @param sheet
* HSSFSheet
* @param ca
* CellRangAddress
* @param style
* CellStyle
* @throws IOException
*/
public static void createExcel(String gameName,List<StatByDrawNumber> statByDrawNumbers,
String filePath, String startDate, String endDate)
throws IOException {/*
DateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
DateFormat df1 = new SimpleDateFormat("yyyyMMddHHmmss");
// 根据指定的文件创建输出流
String fileName = "按期统计" + df1.format(new Date()) + ".xls";
FileOutputStream out = new FileOutputStream(filePath+ fileName);
HSSFWorkbook wb = new HSSFWorkbook();
HSSFSheet sheet = wb.createSheet();
HSSFRow title = sheet.createRow(0);
title.setHeightInPoints(20);
HSSFCell cell = title.createCell(0);
HSSFFont cnFont = wb.createFont();
cnFont.setFontHeightInPoints((short) 20);
cnFont.setBoldweight((short) 30);
cnFont.setFontName("隶书");
HSSFCellStyle cnStyle = wb.createCellStyle();
cnStyle.setFont(cnFont);
cell.setCellStyle(cnStyle);
HSSFRichTextString richText = new HSSFRichTextString(startDate + "日至"
+ endDate + "日广西("+gameName+")期销售明细报表");
cell.setCellValue(richText);
HSSFRow header = sheet.createRow(1);
HSSFFont rowHeaderFont = wb.createFont();
cnFont.setFontHeightInPoints((short) 15);
cnFont.setBoldweight((short) 20);
cnFont.setFontName("隶书");
HSSFCellStyle rowHeaderStyle = wb.createCellStyle();
rowHeaderStyle.setFont(rowHeaderFont);
HSSFCell cell0 = createCell(header, 0, rowHeaderStyle);
cell0.setCellValue("游戏名称");
HSSFCell cell1 = createCell(header, 1, rowHeaderStyle);
cell1.setCellValue("游戏代码");
HSSFCell cell2 = createCell(header, 2, rowHeaderStyle);
cell2.setCellValue("游戏期号");
HSSFCell cell3 = createCell(header, 3, rowHeaderStyle);
cell3.setCellValue("开奖日期");
HSSFCell cell4 = createCell(header, 4, rowHeaderStyle);
cell4.setCellValue("销售总金额(元)");
HSSFCell cell5 = createCell(header, 5, rowHeaderStyle);
cell5.setCellValue("小奖中奖金额(元)");
HSSFCell cell6 = createCell(header, 6, rowHeaderStyle);
cell6.setCellValue("应收金额(元)");
Long totalBetMoney = 0L;
Long smallPrizeMoney = 0L;
Long yue = 0L;
for (int i = 0; i < statByDrawNumbers.size(); i++) {
NewStatByDrawNumber statByDrawNumber = statByDrawNumbers.get(i);
totalBetMoney += statByDrawNumber.getTotalBetMoney();
smallPrizeMoney += statByDrawNumber.getSmallPrizeMoney();
yue += statByDrawNumber.getTotalBetMoney()
- statByDrawNumber.getSmallPrizeMoney();
HSSFRow row = sheet.createRow(i + 2);
HSSFFont font = wb.createFont();
cnFont.setFontHeightInPoints((short) 10);
cnFont.setBoldweight((short) 10);
cnFont.setFontName("隶书");
HSSFCellStyle style = wb.createCellStyle();
rowHeaderStyle.setFont(font);
createCell(row, 0, rowHeaderStyle)
.setCellValue(
DarwNumberUtils.lotteryName.get(statByDrawNumber
.getLtype()));
createCell(row, 1, rowHeaderStyle).setCellValue(
statByDrawNumber.getLtype());
createCell(row, 2, style).setCellValue(
statByDrawNumber.getDrawnumber());
createCell(row, 3, style).setCellValue(
df.format(statByDrawNumber.getDrawtime()));
createCell(row, 4, style).setCellValue(
statByDrawNumber.getTotalBetMoney());
createCell(row, 5, style).setCellValue(
statByDrawNumber.getSmallPrizeMoney());
createCell(row, 6, style).setCellValue(
statByDrawNumber.getTotalBetMoney()
- statByDrawNumber.getSmallPrizeMoney());
}
HSSFRow row = sheet.createRow(statByDrawNumbers.size() + 2);
HSSFFont font = wb.createFont();
cnFont.setFontHeightInPoints((short) 15);
cnFont.setBoldweight((short) 20);
cnFont.setFontName("隶书");
HSSFCellStyle style = wb.createCellStyle();
rowHeaderStyle.setFont(font);
createCell(row, 0, rowHeaderStyle).setCellValue("");
createCell(row, 1, rowHeaderStyle).setCellValue("");
createCell(row, 2, style).setCellValue("合计(元)");
createCell(row, 3, style).setCellValue("");
createCell(row, 4, style).setCellValue(totalBetMoney);
createCell(row, 5, style).setCellValue(smallPrizeMoney);
createCell(row, 6, style).setCellValue(yue);
sheet.setColumnWidth(0, 5000);
sheet.setColumnWidth(1, 5000);
sheet.setColumnWidth(2, 5000);
sheet.setColumnWidth(3, 5000);
sheet.setColumnWidth(4, 5000);
sheet.setColumnWidth(5, 5000);
sheet.setColumnWidth(6, 5000);
// 3.output
sheet.setDisplayGridlines(false);
sheet.setPrintGridlines(false);
HSSFPrintSetup printSetup = sheet.getPrintSetup();
// A4纸
printSetup.setPaperSize(HSSFPrintSetup.A4_PAPERSIZE);
sheet.addMergedRegion(new CellRangeAddress(0, 0, 0, 6));
wb.write(out);
out.close();
*/}
public static void createGXExcel(String gameName,List<GxStatByDrawNumber> statByDrawNumbers,
String filePath, String startDate, String endDate)
throws IOException {/*
DateFormat df = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");
DateFormat df1 = new SimpleDateFormat("yyyyMMddhhmmss");
// 根据指定的文件创建输出流
String fileName = "广西按期统计" + df1.format(new Date()) + ".xls";
FileOutputStream out = new FileOutputStream(filePath+fileName);
HSSFWorkbook wb = new HSSFWorkbook();
HSSFSheet sheet = wb.createSheet();
HSSFRow title = sheet.createRow(0);
title.setHeightInPoints(20);
HSSFCell cell = title.createCell(0);
HSSFFont cnFont = wb.createFont();
cnFont.setFontHeightInPoints((short) 20);
cnFont.setBoldweight((short) 30);
cnFont.setFontName("隶书");
HSSFCellStyle cnStyle = wb.createCellStyle();
cnStyle.setFont(cnFont);
cell.setCellStyle(cnStyle);
HSSFRichTextString richText = new HSSFRichTextString(startDate + "日至"
+ endDate + "日广西("+gameName+")期销售明细报表");
cell.setCellValue(richText);
HSSFRow header = sheet.createRow(1);
HSSFFont rowHeaderFont = wb.createFont();
cnFont.setFontHeightInPoints((short) 15);
cnFont.setBoldweight((short) 20);
cnFont.setFontName("隶书");
HSSFCellStyle rowHeaderStyle = wb.createCellStyle();
rowHeaderStyle.setFont(rowHeaderFont);
HSSFCell cell0 = createCell(header, 0, rowHeaderStyle);
cell0.setCellValue("游戏名称");
HSSFCell cell1 = createCell(header, 1, rowHeaderStyle);
cell1.setCellValue("游戏代码");
HSSFCell cell2 = createCell(header, 2, rowHeaderStyle);
cell2.setCellValue("游戏期号");
HSSFCell cell3 = createCell(header, 3, rowHeaderStyle);
cell3.setCellValue("开奖日期");
HSSFCell cell4 = createCell(header, 4, rowHeaderStyle);
cell4.setCellValue("销售总金额(元)");
HSSFCell cell5 = createCell(header, 5, rowHeaderStyle);
cell5.setCellValue("小奖中奖金额(元)");
HSSFCell cell6 = createCell(header, 6, rowHeaderStyle);
cell6.setCellValue("应付金额(元)");
Long totalBetMoney = 0L;
Long smallPrizeMoney = 0L;
Long yue = 0L;
for (int i = 0; i < statByDrawNumbers.size(); i++) {
GxStatByDrawNumber statByDrawNumber = statByDrawNumbers.get(i);
totalBetMoney += statByDrawNumber.getTotalBetMoney();
smallPrizeMoney += statByDrawNumber.getSmallPrizeMoney();
yue += statByDrawNumber.getTotalBetMoney()
- statByDrawNumber.getSmallPrizeMoney();
HSSFRow row = sheet.createRow(i + 2);
HSSFFont font = wb.createFont();
cnFont.setFontHeightInPoints((short) 10);
cnFont.setBoldweight((short) 10);
cnFont.setFontName("隶书");
HSSFCellStyle style = wb.createCellStyle();
rowHeaderStyle.setFont(font);
createCell(row, 0, rowHeaderStyle)
.setCellValue(
DarwNumberUtils.lotteryName.get(statByDrawNumber
.getLtype()));
createCell(row, 1, rowHeaderStyle).setCellValue(
statByDrawNumber.getLtype());
createCell(row, 2, style).setCellValue(
statByDrawNumber.getDrawnumber());
createCell(row, 3, style).setCellValue(
df.format(statByDrawNumber.getDrawtime()));
createCell(row, 4, style).setCellValue(
statByDrawNumber.getTotalBetMoney());
createCell(row, 5, style).setCellValue(
statByDrawNumber.getSmallPrizeMoney());
createCell(row, 6, style).setCellValue(
statByDrawNumber.getTotalBetMoney()
- statByDrawNumber.getSmallPrizeMoney());
}
HSSFRow row = sheet.createRow(statByDrawNumbers.size() + 2);
HSSFFont font = wb.createFont();
cnFont.setFontHeightInPoints((short) 15);
cnFont.setBoldweight((short) 20);
cnFont.setFontName("隶书");
HSSFCellStyle style = wb.createCellStyle();
rowHeaderStyle.setFont(font);
createCell(row, 0, rowHeaderStyle).setCellValue("");
createCell(row, 1, rowHeaderStyle).setCellValue("");
createCell(row, 2, style).setCellValue("合计(元)");
createCell(row, 3, style).setCellValue("");
createCell(row, 4, style).setCellValue(totalBetMoney);
createCell(row, 5, style).setCellValue(smallPrizeMoney);
createCell(row, 6, style).setCellValue(yue);
sheet.setColumnWidth(0, 5000);
sheet.setColumnWidth(1, 5000);
sheet.setColumnWidth(2, 5000);
sheet.setColumnWidth(3, 5000);
sheet.setColumnWidth(4, 5000);
sheet.setColumnWidth(5, 5000);
sheet.setColumnWidth(6, 5000);
// 3.output
sheet.setDisplayGridlines(false);
sheet.setPrintGridlines(false);
HSSFPrintSetup printSetup = sheet.getPrintSetup();
// A4纸
printSetup.setPaperSize(HSSFPrintSetup.A4_PAPERSIZE);
sheet.addMergedRegion(new CellRangeAddress(0, 0, 0, 6));
wb.write(out);
out.close();
*/}
public static void main(String... args) throws IOException {/*
List<GxStatByDrawNumber> statByDrawNumbers = new ArrayList<GxStatByDrawNumber>();
GxStatByDrawNumber s1 = new GxStatByDrawNumber();
s1.setLtype("QGSLTO");
s1.setDrawnumber("2011001");
s1.setDrawtime(new Date());
s1.setTotalBetMoney(10000L);
s1.setSmallPrizeMoney(1000L);
GxStatByDrawNumber s2 = new GxStatByDrawNumber();
s2.setLtype("QGSLTO");
s2.setDrawnumber("2011001");
s2.setDrawtime(new Date());
s2.setTotalBetMoney(10000L);
s2.setSmallPrizeMoney(1000L);
GxStatByDrawNumber s3 = new GxStatByDrawNumber();
s3.setLtype("QGSLTO");
s3.setDrawnumber("2011001");
s3.setDrawtime(new Date());
s3.setTotalBetMoney(10000L);
s3.setSmallPrizeMoney(1000L);
GxStatByDrawNumber s4 = new GxStatByDrawNumber();
s4.setLtype("QGSLTO");
s4.setDrawnumber("2011001");
s4.setDrawtime(new Date());
s4.setTotalBetMoney(10000L);
s4.setSmallPrizeMoney(1000L);
GxStatByDrawNumber s5 = new GxStatByDrawNumber();
s5.setLtype("QGSLTO");
s5.setDrawnumber("2011001");
s5.setDrawtime(new Date());
s5.setTotalBetMoney(10000L);
s5.setSmallPrizeMoney(1000L);
statByDrawNumbers.add(s1);
statByDrawNumbers.add(s2);
statByDrawNumbers.add(s3);
statByDrawNumbers.add(s4);
statByDrawNumbers.add(s5);
*/}
}
相关推荐
`ExcelUtil` 是一个在Java开发中常用的工具类,用于处理Microsoft Excel文件。这个类通常包含了一系列静态方法,便于开发者对Excel数据进行读取、写入、格式转换等操作,而无需深入理解底层的API细节。Excel文件在...
然后,创建一个名为`ExcelUtil`的工具类,该类包含生成Excel的方法: ```java import org.apache.poi.ss.usermodel.*; import org.apache.poi.xssf.usermodel.XSSFWorkbook; import java.io.FileOutputStream; ...
一个优秀的工具类库应该具有良好的扩展性和自定义性。ExcelUtil可能提供了接口或策略模式,允许用户自定义样式、数据格式等,满足不同场景的需求。 7. **实际应用** ExcelUtil常被用于数据导入导出、报表生成、...
在Java编程中,ExcelUtil是一个常见的工具类,用于处理与Microsoft Excel文件相关的操作,如导入数据、导出数据等。这个工具类的使用极大地简化了开发者处理Excel文件的工作流程,提高了开发效率。以下是对ExcelUtil...
本篇将详细讲解如何利用Java的开源库Apache POI,结合反射机制,通过ExcelUtil工具类简化Excel读取的过程。 Apache POI是一个强大的库,它允许Java程序员创建、修改和展示MS Office格式的文件,包括Excel。在传统的...
在创建Excel工具类之前,确保已经添加了Apache POI的依赖。如果你使用的是Maven,可以在pom.xml文件中添加以下依赖: ```xml <groupId>org.apache.poi <artifactId>poi <version>4.1.2 <groupId>org.apache....
本篇文章将深入探讨如何利用Java的Apache POI库创建一个能够处理`List<Object>`数据的Excel工具类。 Apache POI是一个流行的开源库,它允许程序员创建、修改和显示Microsoft Office格式的文件,包括Excel(.xls和....
然后,调用服务层的方法,将上传的Excel文件传递给Excel工具类进行解析。解析过程中,你可以根据Excel的行和列获取数据,并将其转化为对应的业务对象。注意,要处理可能的异常,如文件格式错误、数据格式不匹配等。 ...
压缩包中的“公共工具类”可能包含了实现上述功能的核心类和方法,如`EasyUIPoIUtils`,你可以通过阅读源码了解其实现细节。示例模板提供了参考,可以帮助你理解如何设计模板文件。调用截图则展示了如何在代码中使用...
开发者可以传入数据集合,工具会自动创建对应的Excel工作表,并填充数据。 4. **高级功能**:可能包含合并单元格、设置样式(如字体、颜色、边框、对齐方式等)、公式计算、图表生成等功能,以满足更复杂的Excel...
例如,我们可以创建一个名为`ExcelUtil`的工具类,包含如下方法: - `static Workbook readExcel(File file)`:读取Excel文件并返回Workbook对象。 - `static void writeExcel(Workbook workbook, File outputFile)...
在Java开发中,ExcelUtil是一个常用的工具类,它简化了基于Apache POI库的Excel文件解析和生成过程。Apache POI是Apache软件基金会的一个开源项目,提供了读取和写入Microsoft Office格式文件的能力,包括Excel。...
在这个Excel工具类中,泛型被用来创建一个通用的方法,可以处理任何类型的对象,无需进行显式类型转换,提高了代码的灵活性和可维护性。 2. **反射**:Java反射机制允许程序在运行时动态地获取类的信息(如类名、...
首先,`ExcelUtil.java` 文件很可能是这个工具类的核心实现,它包含了对Excel文件的各种操作方法。Apache POI提供了HSSFWorkbook(用于处理.xls格式)和XSSFWorkbook(用于处理.xlsx格式)两个主要的类,它们分别...
"Excel导入工具类"就是为了解决这个问题而设计的一种高效、便捷的开发工具。这个工具类的主要目的是简化Excel导入的开发流程,节省开发时间,从而提高整体的开发效率。 在传统的Excel导入开发过程中,开发者需要...
`ExportExcelUtil`是核心工具类,提供了各种方法来创建、填充和导出Excel文件。它可能包括以下功能: 1. **导出简单Excel**:创建一个单个工作表,包含指定数据的Excel文件。 2. **导出多Sheet Excel**:创建包含多...
ExcelUtils工具类是一个在Java开发中广泛使用的库,它的主要功能是帮助开发者便捷地按照预设模板导出Excel文件。这种工具极大地简化了处理Excel数据的复杂性,使得程序员能够快速实现数据的导出功能,而无需深入了解...