`
zengshaotao
  • 浏览: 792119 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

poi操作Excel, 各种具体操作和解释

 
阅读更多

java读取excel文件的顺序是: 
Excel文件->工作表->行->单元格 对应到POI中,为:workbook->sheet->row->cell 
注意: 
注意:   
   1.sheet, 以0开始,以workbook.getNumberOfSheets()-1结束 
   2.row, 以0开始(getFirstRowNum),以getLastRowNum结束 
   3.cell, 以0开始(getFirstCellNum),以getLastCellNum结束, 
     结束的数目不知什么原因与显示的长度不同,可能会偏长 

 

//import org.apache.poi.ss.usermodel.contrib.CellUtil;

//import org.apache.poi.ss.usermodel.contrib.RegionUtil;

这两个类已更换到 这两个类移动是3.7开始变的

//import org.apache.poi.ss.util.CellUtil;

 

//import org.apache.poi.ss.util.RegionUtil;

package com.svse.test;

 

 

import java.awt.Color;

import java.io.FileInputStream;

import java.io.FileNotFoundException;

import java.io.FileOutputStream;

import java.io.IOException;

import java.io.InputStream;

import java.util.Calendar;

import java.util.Date;

 

 

import org.apache.poi.hssf.usermodel.HSSFCell;

import org.apache.poi.hssf.usermodel.HSSFClientAnchor;

import org.apache.poi.hssf.usermodel.HSSFFooter;

import org.apache.poi.hssf.usermodel.HSSFPatriarch;

import org.apache.poi.hssf.usermodel.HSSFRichTextString;

import org.apache.poi.hssf.usermodel.HSSFShape;

import org.apache.poi.hssf.usermodel.HSSFSheet;

import org.apache.poi.hssf.usermodel.HSSFSimpleShape;

import org.apache.poi.hssf.usermodel.HSSFTextbox;

import org.apache.poi.hssf.usermodel.HSSFWorkbook;

import org.apache.poi.hssf.util.HSSFColor;

import org.apache.poi.openxml4j.exceptions.InvalidFormatException;

import org.apache.poi.ss.usermodel.Cell;

import org.apache.poi.ss.usermodel.CellStyle;

import org.apache.poi.ss.usermodel.ClientAnchor;

import org.apache.poi.ss.usermodel.CreationHelper;

import org.apache.poi.ss.usermodel.DataFormat;

import org.apache.poi.ss.usermodel.DateUtil;

import org.apache.poi.ss.usermodel.Drawing;

import org.apache.poi.ss.usermodel.Font;

import org.apache.poi.ss.usermodel.IndexedColors;

import org.apache.poi.ss.usermodel.Picture;

import org.apache.poi.ss.usermodel.PrintSetup;

import org.apache.poi.ss.usermodel.RichTextString;

import org.apache.poi.ss.usermodel.Row;

import org.apache.poi.ss.usermodel.Sheet;

import org.apache.poi.ss.usermodel.Workbook;

import org.apache.poi.ss.usermodel.WorkbookFactory;

//import org.apache.poi.ss.usermodel.contrib.CellUtil;

//import org.apache.poi.ss.usermodel.contrib.RegionUtil;

import org.apache.poi.ss.util.CellRangeAddress;

import org.apache.poi.ss.util.CellReference;

import org.apache.poi.ss.util.CellUtil;

import org.apache.poi.ss.util.RegionUtil;

import org.apache.poi.util.IOUtils;

import org.apache.poi.xssf.usermodel.XSSFCellStyle;

import org.apache.poi.xssf.usermodel.XSSFWorkbook;

import org.junit.BeforeClass;

import org.junit.Test;

 

 

/**

 * @author WESTDREAM

 * @since 2010-8-7 下午10:34:03

 */

public class POIExcelTest {

 

 

/**

* @throws java.lang.Exception

*/

public static final String XLS_WORKBOOK_LOCATION = "D:/workbook.xls";

public static final String XLS_OR_XLSX_DIR = "D:/";

public static final String XLSX_WORKBOOK_LOCATION = "D:/workbook.xlsx";

public static final String IMAGE_LOCATION = "book.jpg";

 

 

@BeforeClass

public static void setUpBeforeClass() throws Exception {

 

 

}

 

 

@Test

public void testWriteExcel() {

// ## 重复利用 的对象 ##//

Workbook wb = null;

FileOutputStream fileOut = null;

CellStyle cellStyle = null;

Cell cell = null;

Font font = null;

 

 

/**

* EXCEL早期版本

*/

try {

// ## 创建早期EXCEL的Workbook ##//

wb = new HSSFWorkbook();

// ## 获取HSSF和XSSF的辅助类 ##//

CreationHelper createHelper = wb.getCreationHelper();

// ## 创建一个名为“New Sheet”的Sheet ##//

Sheet sheet = wb.createSheet("New Sheet");

 

 

/** 第一行 --- CELL创建,数据填充及日期格式 **/

Row row1 = sheet.createRow(0);

// Cell cell = row.createCell(0);

// cell.setCellValue(1);

 

 

// ## 在相应的位置填充数据 ##//

row1.createCell(0).setCellValue(1);

row1.createCell(1).setCellValue(1.2);

row1.createCell(2).setCellValue(

createHelper.createRichTextString("CreationHelper---字符串"));

row1.createCell(3).setCellValue(true);

 

 

// ## 填充日期类型的数据---未设置Cell Style ##//

row1.createCell(4).setCellValue(new Date());

// ## 填充日期类型的数据---已设置Cell Style ##//

cellStyle = wb.createCellStyle();

cellStyle.setDataFormat(createHelper.createDataFormat().getFormat(

"yyyy年MM月dd日 hh:mm:ss"));

// cellStyle.setDataFormat(createHelper.createDataFormat().getFormat("mm/dd/yyyy h:mm"));

cellStyle.setDataFormat(createHelper.createDataFormat().getFormat(

"yyyy-MM-dd hh:mm:ss"));

cell = row1.createCell(5);

cell.setCellValue(new Date());

cell.setCellStyle(cellStyle);

// ## 另一种创建日期的方法 ##//

/*

* cell = row1.createCell(6);

* cell.setCellValue(Calendar.getInstance());

* cell.setCellStyle(cellStyle);

*/

 

 

/** 第二行 --- 数据类型 **/

Row row2 = sheet.createRow(1);

row2.createCell(0).setCellValue(1.1);

row2.createCell(1).setCellValue(new Date());

row2.createCell(2).setCellValue(Calendar.getInstance());

row2.createCell(3).setCellValue("字符串");

row2.createCell(4).setCellValue(true);

// ## 错误的CELL数据格式 ##//

row2.createCell(5).setCellType(HSSFCell.CELL_TYPE_ERROR);

 

 

/** 第三行 --- CELL的各种对齐方式 **/

Row row3 = sheet.createRow(2);

row3.setHeightInPoints(30);

// ## 水平居中,底端对齐 ##//

createCell(wb, row3, (short) 0, XSSFCellStyle.ALIGN_CENTER,

XSSFCellStyle.VERTICAL_BOTTOM);

// ## 水平居中,垂直居中 ##//

createCell(wb, row3, (short) 1,

XSSFCellStyle.ALIGN_CENTER_SELECTION,

XSSFCellStyle.VERTICAL_BOTTOM);

// ## 填充 ,垂直居中 ##//

createCell(wb, row3, (short) 2, XSSFCellStyle.ALIGN_FILL,

XSSFCellStyle.VERTICAL_CENTER);

// ## 左对齐,垂直居中 ##//

createCell(wb, row3, (short) 3, XSSFCellStyle.ALIGN_GENERAL,

XSSFCellStyle.VERTICAL_CENTER);

// ## 左对齐,顶端对齐 ##//

createCell(wb, row3, (short) 4, XSSFCellStyle.ALIGN_JUSTIFY,

XSSFCellStyle.VERTICAL_JUSTIFY);

// ## 左对齐,顶端对齐 ##//

createCell(wb, row3, (short) 5, XSSFCellStyle.ALIGN_LEFT,

XSSFCellStyle.VERTICAL_TOP);

// ## 右对齐,顶端对齐 ##//

createCell(wb, row3, (short) 6, XSSFCellStyle.ALIGN_RIGHT,

XSSFCellStyle.VERTICAL_TOP);

 

 

/** 第四行 --- CELL边框 **/

Row row4 = sheet.createRow(3);

cell = row4.createCell(1);

cell.setCellValue(4);

cellStyle = wb.createCellStyle();

// ## 设置底部边框为THIN ##//

cellStyle.setBorderBottom(CellStyle.BORDER_THIN);

// ## 设置底部边框颜色为黑色 ##//

cellStyle.setBottomBorderColor(IndexedColors.BLACK.getIndex());

// ## 设置左边边框为THIN ##//

cellStyle.setBorderLeft(CellStyle.BORDER_THIN);

// ## 设置左边边框颜色为红色 ##//

cellStyle.setLeftBorderColor(IndexedColors.RED.getIndex());

// ## 设置右边边框为THIN ##//

cellStyle.setBorderRight(CellStyle.BORDER_THIN);

// ## 设置右边边框颜色为蓝色 ##//

cellStyle.setRightBorderColor(IndexedColors.BLUE.getIndex());

// ## 设置顶部边框为MEDIUM DASHED ##//

cellStyle.setBorderTop(CellStyle.BORDER_MEDIUM_DASHED);

// ## 设置顶部边框颜色为黑色 ##//

cellStyle.setTopBorderColor(IndexedColors.BLACK.getIndex());

cell.setCellStyle(cellStyle);

 

 

/** 第五行 --- 填充与颜色 **/

Row row5 = sheet.createRow((short) 4);

// ## Aqua背景 ##//

cellStyle = wb.createCellStyle();

cellStyle.setFillBackgroundColor(IndexedColors.AQUA.getIndex());

// ## 设置填充模式为BIG SPOTS ##//

cellStyle.setFillPattern(CellStyle.BIG_SPOTS);

cell = row5.createCell((short) 1);

cell.setCellValue("Aqua背景");

cell.setCellStyle(cellStyle);

 

 

// ## 橙色前景色(相对 于CELL背景) ##//

cellStyle = wb.createCellStyle();

cellStyle.setFillForegroundColor(IndexedColors.ORANGE.getIndex());

// ## 设置填充模式为SOLID FOREGROUND ##//

cellStyle.setFillPattern(CellStyle.SOLID_FOREGROUND);

cell = row5.createCell((short) 2);

cell.setCellValue("橙色前景色");

cell.setCellStyle(cellStyle);

 

 

/** 第六行 --- 合并单元格 **/

Row row6 = sheet.createRow((short) 5);

cell = row6.createCell((short) 4);

cell.setCellValue("合并单元格测试");

// ## Wrong:EXCEL 2007中打开workbook.xls文件看不到"合并单元格测试",但单元格已经合并了 ##//

/*

* sheet.addMergedRegion(new CellRangeAddress( 3, //first row

* (0-based) 5, //last row (0-based) 4, //first column (0-based) 6

* //last column (0-based) ));

*/

// ## 正确合并单元格 注意:与上不同的是first row=last row ##//

sheet.addMergedRegion(new CellRangeAddress(5, // first row (0-based)

5, // last row (0-based)

4, // first column (0-based)

6// last column (0-based)

));

 

 

/** 第七行 --- 字体 **/

Row row7 = sheet.createRow(6);

// ## 创建字体 ##//

// 注意:POI限制一个Workbook创建的Font对象最多为32767,所以不要为每个CELL创建一个字体,建议重用字体

font = wb.createFont();

// ## 设置字体大小为24 ##//

font.setFontHeightInPoints((short) 24);

// ## 设置字体样式为华文隶书 ##//

font.setFontName("华文隶书");

// ## 斜体 ##//

font.setItalic(true);

// ## 添加删除线 ##//

font.setStrikeout(true);

// ## 将字体添加到样式中 ##//

cellStyle = wb.createCellStyle();

cellStyle.setFont(font);

cell = row7.createCell(1);

cell.setCellValue("字体测试");

cell.setCellStyle(cellStyle);

 

 

/** 第八行 --- 自定义颜色 **/

Row row8 = sheet.createRow(7);

cell = row8.createCell(0);

cell.setCellValue("自定义颜色测试");

cellStyle = wb.createCellStyle();

// ## 设置填充前景色为LIME ##//

cellStyle.setFillForegroundColor(HSSFColor.LIME.index);

// ## 设置填充模式为SOLID FOREGROUND ##//

cellStyle.setFillPattern(CellStyle.SOLID_FOREGROUND);

font = wb.createFont();

// ## 设置字体颜色为红色 ##//

font.setColor(HSSFColor.RED.index);

cellStyle.setFont(font);

cell.setCellStyle(cellStyle);

 

 

/*

* cell.setCellValue("自定义颜色测试Palette"); //creating a custom palette

* for the workbook HSSFPalette palette =

* ((HSSFWorkbook)wb).getCustomPalette(); //replacing the standard

* red with freebsd.org red

* palette.setColorAtIndex(HSSFColor.RED.index, (byte) 153, //RGB

* red (0-255) (byte) 0, //RGB green (byte) 0 //RGB blue );

* //replacing lime with freebsd.org gold

* palette.setColorAtIndex(HSSFColor.LIME.index, (byte) 255, (byte)

* 204, (byte) 102);

*/

 

 

/** 第九行 --- 换行 **/

Row row9 = sheet.createRow(8);

cell = row9.createCell(2);

cell.setCellValue("使用 /n及Word-wrap创建一个新行");

cellStyle = wb.createCellStyle();

// ## 设置WrapText为true ##//

cellStyle.setWrapText(true);

cell.setCellStyle(cellStyle);

// ## 设置行的高度以适应新行 ---两行##//

row9.setHeightInPoints((2 * sheet.getDefaultRowHeightInPoints()));

// ## 调整列宽 ##//

sheet.autoSizeColumn(2);

 

 

/** 第十行 --- 数据格式 **/

DataFormat format = wb.createDataFormat();

 

 

Row row10 = sheet.createRow(9);

cell = row10.createCell(0);

cell.setCellValue(11111.25);

cellStyle = wb.createCellStyle();

// ## 一位小数 ##//

cellStyle.setDataFormat(format.getFormat("0.0"));

cell.setCellStyle(cellStyle);

 

 

cell = row10.createCell(1);

cell.setCellValue(11111.25);

cellStyle = wb.createCellStyle();

// ## 四位小数,千位逗号隔开 ##//

// #,###.0000效果一样

cellStyle.setDataFormat(format.getFormat("#,##0.0000"));

cell.setCellStyle(cellStyle);

 

 

// ## 将文件写到硬盘上 ##//

fileOut = new FileOutputStream(XLS_WORKBOOK_LOCATION);

wb.write(fileOut);

fileOut.close();

} catch (FileNotFoundException e) {

e.printStackTrace();

} catch (IOException e) {

e.printStackTrace();

}

 

 

/**

* EXCEL 2007及以后

*/

/*

* try { wb = new XSSFWorkbook(); wb.createSheet("sheet1"); Cell cell =

* row.createCell( 0); cell.setCellValue("custom XSSF colors");

* CellStyle style1 = wb.createCellStyle();

* style1.setFillForegroundColor(new XSSFColor(new java.awt.Color(128,

* 0, 128))); style1.setFillPattern(CellStyle.SOLID_FOREGROUND); fileOut

* = new FileOutputStream("d:/workbook.xlsx"); wb.write(fileOut);

* fileOut.close(); } catch (FileNotFoundException e) {

* e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); }

*/

 

 

}

 

 

/**

* 创建相应格式的CELL

*/

public void createCell(Workbook wb, Row row, short column, short halign,

short valign) {

Cell cell = row.createCell(column);

// ## 给CELL赋值 ##//

cell.setCellValue("对齐排列");

CellStyle cellStyle = wb.createCellStyle();

// ## 设置水平对齐方式 ##//

cellStyle.setAlignment(halign);

// ## 设置垂直对齐方式 ##//

cellStyle.setVerticalAlignment(valign);

// ## 添加CELL样式 ##//

cell.setCellStyle(cellStyle);

}

 

 

/**

* 测试POI EXCEL迭代和或CELL中的值

*/

@Test

public void testExcelIteratorAndCellContents() {

try {

// ## 创建HSSFWorkbook实例 ##//

Workbook wb = new HSSFWorkbook(new FileInputStream(

XLS_WORKBOOK_LOCATION));

// ## 获得第一个SHEET ##//

Sheet sheet = wb.getSheetAt(0); // or we could cast into

// HSSFSheet,that doesn't matter

/** 第一种迭代方法 **/

/*

* //## 迭代ROW ##// for (Iterator<Row> rit = sheet.rowIterator();

* rit.hasNext(); ) { Row row = rit.next(); //## 迭代CELL ##// for

* (Iterator<Cell> cit = row.cellIterator(); cit.hasNext(); ) { Cell

* cell = cit.next(); System.out.println(cell); } }

*/

/** 第二种迭代方法 **/

for (Row row : sheet) {

for (Cell cell : row) {

// ## 获取CellReference对象 ##/

CellReference cellRef = new CellReference(row.getRowNum(),

cell.getColumnIndex());

System.out.print(cellRef.formatAsString());

System.out.print(" - ");

// ## 根据CELL值类型进行相应处理 ##/

switch (cell.getCellType()) {

case Cell.CELL_TYPE_STRING:

System.out.println(cell.getRichStringCellValue()

.getString());

break;

case Cell.CELL_TYPE_NUMERIC:

// ## yyyy年mm月dd日 hh:mm:ss此种格式日期不能识别 ##//

// ## mm/dd/yyyy h:mm,yyyy-MM-dd

// hh:mm:ss可以识别,估计是POI对中文日期支持不怎么好的问题 ##//

if (DateUtil.isCellDateFormatted(cell)) {

System.out.println(cell.getDateCellValue());

} else {

System.out.println(cell.getNumericCellValue());

}

break;

case Cell.CELL_TYPE_BOOLEAN:

System.out.println(cell.getBooleanCellValue());

break;

case Cell.CELL_TYPE_FORMULA:

System.out.println(cell.getCellFormula());

break;

case Cell.CELL_TYPE_ERROR:

System.out.println(cell.getErrorCellValue());

break;

default:

System.out.println();

}

}

}

 

 

} catch (FileNotFoundException e) {

e.printStackTrace();

} catch (IOException e) {

e.printStackTrace();

}

}

 

 

/**

* 修改文件测试

*/

@Test

public void testReadingAndRewritingWorkbooks() {

InputStream inp = null;

try {

inp = new FileInputStream(XLS_WORKBOOK_LOCATION);

// inp = new FileInputStream("workbook.xlsx");

// ## 获得要修改的Workbook ##/

Workbook wb = WorkbookFactory.create(inp);

// ## 获取要修改的Sheet ##//

Sheet sheet = wb.getSheetAt(0);

// ## 获取要修改的Row ##//

Row row = sheet.getRow(1);

// ## 获取要修改的Cell,如果没有相应位置的Cell那么就创建一个 ##//

Cell cell = row.getCell(2);

if (cell == null)

cell = row.createCell(2);

// ## 写入修改数据 ##//

cell.setCellType(Cell.CELL_TYPE_STRING);

cell.setCellValue("修改文件测试");

 

 

// ## 将文件写到硬盘上 ##//

FileOutputStream fileOut = new FileOutputStream(

XLS_WORKBOOK_LOCATION);

wb.write(fileOut);

fileOut.close();

} catch (FileNotFoundException e) {

e.printStackTrace();

} catch (InvalidFormatException e) {

e.printStackTrace();

} catch (IOException e) {

e.printStackTrace();

}

}

 

 

/**

* 暂时没看到有什么区别

*/

@Test

public void testFitSheetToOnePage() {

try {

Workbook wb = new HSSFWorkbook();

Sheet sheet = wb.createSheet("format sheet");

PrintSetup ps = sheet.getPrintSetup();

 

 

sheet.setAutobreaks(true);

 

 

ps.setFitHeight((short) 1);

ps.setFitWidth((short) 1);

// Create various cells and rows for spreadsheet.

FileOutputStream fileOut = new FileOutputStream(

XLS_WORKBOOK_LOCATION);

wb.write(fileOut);

fileOut.close();

} catch (Exception e) {

e.printStackTrace();

}

}

 

 

/**

* 设置打印区域测试

*/

@Test

public void testSetPrintArea() {

/**

* 注意:我测试的时候用的是EXCEL 2007打开的,效果不明显,只能控制列且列好像也是不正确的。 但是我用EXCEL

* 2007转换了一下,xls,xlsx的都正确了,目前还不知道是什么问题。

*/

try {

Workbook wb = new HSSFWorkbook();

Sheet sheet = wb.createSheet("Print Area Sheet");

Row row = sheet.createRow(0);

row.createCell(0).setCellValue("第一个单元格");

row.createCell(1).setCellValue("第二个单元格");

row.createCell(2).setCellValue("第三个单元格");

row = sheet.createRow(1);

row.createCell(0).setCellValue("第四个单元格");

row.createCell(1).setCellValue("第五个单元格");

row = sheet.createRow(2);

row.createCell(0).setCellValue("第六个单元格");

row.createCell(1).setCellValue("第七个单元格");

// ## 设置打印区域 A1--C2 ##//

// wb.setPrintArea(0, "$A$1:$C$2");

// ## 或者使用以下方法设置 ##//

wb.setPrintArea(0, // Sheet页

0, // 开始列

2, // 结束列

0, // 开始行

1// 结束行

);

 

 

FileOutputStream fileOut = new FileOutputStream(

XLS_WORKBOOK_LOCATION);

wb.write(fileOut);

fileOut.close();

} catch (FileNotFoundException e) {

e.printStackTrace();

} catch (IOException e) {

e.printStackTrace();

}

 

 

}

 

 

/**

* 设置页脚测试 用“页面布局”可以看到效果 下列代码只适用xls

*/

@Test

public void testSetPageNumbersOnFooter() {

try {

HSSFWorkbook wb = new HSSFWorkbook();

HSSFSheet sheet = wb.createSheet("Footer Test");

// ## 获得页脚 ##/

HSSFFooter footer = sheet.getFooter();

Row row;

// ## 将 当前页/总页数 写在右边 ##/

footer.setRight(HSSFFooter.page() + "/" + HSSFFooter.numPages());

for (int i = 0; i < 100; i++) {

row = sheet.createRow(i);

for (int j = 0; j < 20; j++) {

row.createCell(j).setCellValue("A" + i + j);

}

}

FileOutputStream fileOut = new FileOutputStream(

XLS_WORKBOOK_LOCATION);

wb.write(fileOut);

fileOut.close();

} catch (FileNotFoundException e) {

e.printStackTrace();

} catch (IOException e) {

e.printStackTrace();

}

 

 

}

 

 

/**

* 测试一些POI提供的比较方便的函数 文档中有些以HSSF为前缀的类的方法以过时(e.g: HSSFSheet, HSSFCell etc.),

* 测试的时候我去掉了HSSF前缀,当然也就是现在POI推荐的接口(Sheet,Row,Cell etc.)

*/

@Test

public void testConvenienceFunctions() {

try {

Workbook wb = new HSSFWorkbook();

Sheet sheet1 = wb.createSheet("Convenience Functions");

// ## 设置Sheet的显示比例 这里是3/4,也就是 75% ##//

sheet1.setZoom(3, 4);

// ## 合并单元格 ##//

Row row = sheet1.createRow((short) 1);

Row row2 = sheet1.createRow((short) 2);

Cell cell = row.createCell((short) 1);

cell.setCellValue("合并单元格测试");

// ## 创建合并区域 ##//

CellRangeAddress region = new CellRangeAddress(1, (short) 1, 4,

(short) 4);

sheet1.addMergedRegion(region);

 

 

// ## 设置边框及边框颜色 ##//

final short borderMediumDashed = CellStyle.BORDER_MEDIUM_DASHED;

RegionUtil.setBorderBottom(borderMediumDashed, region, sheet1, wb);

RegionUtil.setBorderTop(borderMediumDashed, region, sheet1, wb);

RegionUtil.setBorderLeft(borderMediumDashed, region, sheet1, wb);

RegionUtil.setBorderRight(borderMediumDashed, region, sheet1, wb);

// ## 设置底部边框的颜色 ##//

RegionUtil.setBottomBorderColor(HSSFColor.AQUA.index, region,

sheet1, wb);

// ## 设置顶部边框的颜色 ##//

RegionUtil.setTopBorderColor(HSSFColor.AQUA.index, region, sheet1,

wb);

// ## 设置左边边框的颜色 ##//

RegionUtil.setLeftBorderColor(HSSFColor.AQUA.index, region, sheet1,

wb);

// ## 设置右边边框的颜色 ##//

RegionUtil.setRightBorderColor(HSSFColor.AQUA.index, region,

sheet1, wb);

 

 

// ## CellUtil的一些用法 ##/

CellStyle style = wb.createCellStyle();

style.setIndention((short) 10);

CellUtil.createCell(row, 8, "CellUtil测试", style);

Cell cell2 = CellUtil.createCell(row2, 8, "CellUtil测试");

// ## 设置对齐方式为居中对齐 ##//

CellUtil.setAlignment(cell2, wb, CellStyle.ALIGN_CENTER);

 

 

// ## 将Workbook写到硬盘上 ##//

FileOutputStream fileOut = new FileOutputStream(

XLS_WORKBOOK_LOCATION);

wb.write(fileOut);

fileOut.close();

} catch (FileNotFoundException e) {

e.printStackTrace();

} catch (IOException e) {

e.printStackTrace();

}

}

 

 

/**

* 测试冻结窗格和拆分

*/

@Test

public void testSplitAndFreezePanes() {

try {

Workbook wb = new HSSFWorkbook();

Sheet sheet1 = wb.createSheet("冻结首行Sheet");

Sheet sheet2 = wb.createSheet("冻结首列Sheet");

Sheet sheet3 = wb.createSheet("冻结两行两列 Sheet");

Sheet sheet4 = wb.createSheet("拆分Sheet");

 

 

/** 冻结窗格 **/

/*

* createFreezePane( colSplit, rowSplit, topRow, leftmostColumn )

* colSplit 冻结线水平位置 rowSplit 冻结线垂直位置 topRow Top row visible in

* bottom pane leftmostColumn Left column visible in right pane.

*/

// ## 冻结首行 ##//

sheet1.createFreezePane(0, 1, 0, 1);

// ## 冻结首列 ##//

sheet2.createFreezePane(1, 0, 1, 0);

// ## 冻结两行两列 ##//

sheet3.createFreezePane(2, 2);

// ## 拆分,左下的为面板为激活状态 ##//

sheet4.createSplitPane(2000, 2000, 0, 0, Sheet.PANE_LOWER_LEFT);

 

 

FileOutputStream fileOut = new FileOutputStream(

XLS_WORKBOOK_LOCATION);

wb.write(fileOut);

fileOut.close();

} catch (FileNotFoundException e) {

e.printStackTrace();

} catch (IOException e) {

e.printStackTrace();

}

}

 

 

/**

* 测试简单图形

*/

@Test

public void testDrawingShapes() {

try {

Workbook wb = new HSSFWorkbook();

Sheet sheet = wb.createSheet("Drawing Shapes");

// ## 得到一个HSSFPatriarch对象,有点像画笔但是注意区别 ##//

HSSFPatriarch patriarch = (HSSFPatriarch) sheet

.createDrawingPatriarch();

/*

* 构造器: HSSFClientAnchor(int dx1, int dy1, int dx2, int dy2, short

* col1, int row1, short col2, int row2) 描述:

* 创建HSSFClientAnchor类的实例,设置该anchor的顶-左和底-右坐标(相当于锚点,也就是图像出现的位置,大小等).

* Creates a new client anchor and sets the top-left and

* bottom-right coordinates of the anchor. 参数: dx1 第一个单元格的x坐标 dy1

* 第一个单元格的y坐标 dx2 第二个单元格的x坐标 dy2 第二个单元格的y坐标 col1 第一个单元格所在列 row1

* 第一个单元格所在行 col2 第二个单元格所在列 row2 第二个单元格所在行

*/

HSSFClientAnchor anchor = new HSSFClientAnchor(0, 0, 512, 255,

(short) 1, 0, (short) 1, 0);

// ## 通过HSSFClientAnchor类的对象创建HSSFSimpleShape的实例 ##//

HSSFSimpleShape shape = patriarch.createSimpleShape(anchor);

// ## 画个椭圆 ##//

shape.setShapeType(HSSFSimpleShape.OBJECT_TYPE_OVAL);

 

 

// ## 这几个是没问题的 ##//

// shape.setLineStyleColor(10,10,10);

// shape.setFillColor(90,10,200);

// shape.setLineStyleColor(HSSFColor.BLUE.index); //设置不了,尚不知原因

// ## 设置线条颜色为红色 ##//

// shape.setLineStyleColor(Color.BLUE.getRGB()); //搞不清楚为什是反的BLUE:红色

// RED:蓝色,是不是开发POI的有点色盲,JUST KIDDING!

// ## 设置填充颜色为灰色 ##//

shape.setFillColor(Color.GRAY.getRGB()); // 这个又可以

// ## 设置线条宽度为3pt ##//

shape.setLineWidth(HSSFShape.LINEWIDTH_ONE_PT * 3);

// ## 设置线条的样式为点式 ##//

shape.setLineStyle(HSSFShape.LINESTYLE_DOTSYS);

 

 

// ## 创建文本框并填充文字 “创建文本框” ##//

HSSFTextbox textbox = patriarch.createTextbox(new HSSFClientAnchor(

0, 0, 0, 0, (short) 1, 1, (short) 2, 2));

RichTextString text = new HSSFRichTextString("创建文本框");

// ## 创建字体 ##//

Font font = wb.createFont();

// ## 斜体 ##//

font.setItalic(true);

// ## 设置字体颜色为蓝色 ##//

// font.setColor((short)Color.BLUE.getBlue()); not work

font.setColor(HSSFColor.BLUE.index);

// ## 添加字体 ##//

text.applyFont(font);

textbox.setString(text);

 

 

// ## 将文件写到硬盘上 ##//

FileOutputStream fileOut = new FileOutputStream(

XLS_WORKBOOK_LOCATION);

wb.write(fileOut);

fileOut.close();

} catch (FileNotFoundException e) {

e.printStackTrace();

} catch (IOException e) {

e.printStackTrace();

}

}

 

 

/**

* 添加图片到工作薄测试 已测试PNG,JPG,GIF

*/

@Test

public void testImages() {

try {

// ## 创建一个新的工作薄 ##//

Workbook wb = new XSSFWorkbook(); // or new HSSFWorkbook();

 

 

// ## 添加图片到该工作薄 ##//

InputStream is = new FileInputStream(IMAGE_LOCATION);

byte[] bytes = IOUtils.toByteArray(is);

int pictureIdx = wb.addPicture(bytes, Workbook.PICTURE_TYPE_JPEG);

is.close();

 

 

CreationHelper helper = wb.getCreationHelper();

 

 

// ## 创建一个名为“添加图片”的Sheet ##//

Sheet sheet = wb.createSheet("添加图片");

 

 

// ## 创建一个DrawingPatriarch实例 ##//

Drawing drawing = sheet.createDrawingPatriarch();

 

 

// ## 设置图片的形状,位置等 ##//

ClientAnchor anchor = helper.createClientAnchor();

// set top-left corner of the picture,

// subsequent call of Picture#resize() will operate relative to it

anchor.setCol1(3);

anchor.setRow1(2);

Picture pict = drawing.createPicture(anchor, pictureIdx);

// ## 自动设置图片的大小 注意:只支持PNG,JPG,GIF(BMP未测试)##//

pict.resize();

 

 

// ## 保存Workbook ##//

String file = "picture.xls";

if (wb instanceof XSSFWorkbook)

file += "x";

FileOutputStream fileOut = new FileOutputStream(XLS_OR_XLSX_DIR

+ file);

wb.write(fileOut);

fileOut.close();

} catch (FileNotFoundException e) {

e.printStackTrace();

} catch (IOException e) {

e.printStackTrace();

}

 

 

}

}

 

 

分享到:
评论

相关推荐

    poi 操作excel模板

    本篇将深入探讨如何利用Apache POI来操作Excel模板,以及如何读取数据并将其填充到新生成的文件中,最终提供下载。 首先,你需要在项目中引入Apache POI的依赖。如果你使用的是Maven,可以在pom.xml文件中添加以下...

    POI生成Excel POI操作Excel POI读取Excel POI类库

    Apache POI是一个强大的Java库,专门用于处理...通过lib.rar和Poi02.rar中的示例代码,你可以更深入地了解和学习POI操作Excel的具体实现。在实践中,结合这些资源,你将能够熟练地在Java Web项目中集成Excel处理功能。

    POI操作Excel的封装

    在这个场景中,"POI操作Excel的封装"指的是对POI API进行的高级抽象和简化,以便于开发人员更方便地处理Excel文件。通过反射和约定,可以创建一个易于使用的API,隐藏底层复杂的POI细节。 反射是Java编程语言中的一...

    POI操作Excel完美生成水印

    在Java编程领域,...总的来说,通过Apache POI库,开发者可以方便地对Excel文件进行各种操作,包括添加水印,从而提高文档的安全性和专业性。这个过程涉及到Java图形处理、Excel文件结构理解和POI API的熟练运用。

    基于POI的Excel操作Java类

    为更方便的使用POI的API来操作Excel(2003)文件,对POI中针对Excel文件的读写进行了简单封装。此类中包含以下功能: 1.根据模板创建Excel文件 2.获取及更新Excel文件内容 3.创建、复制Sheet 4.设置Sheet名称 ... ...

    JXL 和 POI 操作Excel 表格

    使用POI操作Excel的基本步骤与JXL类似,但POI的API更为复杂和强大: 1. 引入POI库的依赖。 2. 创建`Workbook`对象,可以是HSSFWorkbook(.xls)或XSSFWorkbook(.xlsx)。 3. 添加`Sheet`,然后创建`Row`和`Cell`。...

    poi操作excel全部jar包

    "poi操作excel全部jar包"指的是使用Apache POI进行Excel操作所需的所有库文件集合,通常包含多个JAR文件,每个文件服务于不同的功能模块。 Apache POI 主要分为三个部分: 1. **HSSF**: 这是处理Microsoft Excel的...

    POI使用Excel模板文件循环输出行并导出Excel

    总结,Apache POI提供了一套完整的API,使得在Java中操作Excel文件变得简单。通过循环读取数据和应用模板,我们可以快速生成大量定制化的Excel报告。在"poiDemo2"这个示例中,你可以找到具体实现这些步骤的代码,...

    POI操作excel的导入与导出

    标题 "POI操作excel的导入与导出" 涉及到的是Apache POI库,一个广泛用于Java平台上的Microsoft Office文档处理库。这个库允许开发者读取、创建和修改Excel(.xls和.xlsx)文件。这篇博文可能是介绍如何利用POI进行...

    POI向excel中插入图片

    POI提供了HSSFPicture类和XSSFPicture类(分别对应于.HSSF和.XSSF,即Excel 2003和2007以上的版本)来处理这些图片。 **1. 引入依赖** 在Java项目中,你需要在pom.xml文件中添加Apache POI的相关依赖,例如: ```...

    POI操作Excel总结实例

    这个"POI操作Excel总结实例"的资料可能包含了一系列示例代码,教你如何利用Apache POI库来读取、写入和操作Excel文件。下面,我将详细讲解关于POI操作Excel的一些关键知识点。 1. **创建Excel工作簿(Workbook)** ...

    POI操作excel的java源代码与所需要的jar包poi3.0.1

    在"POI操作excel的java源代码与所需要的jar包poi3.0.1"中,我们聚焦于使用Apache POI 3.0.1版本来创建和读取Excel文件。这个压缩包包含以下内容: 1. `poi-3.0.1-FINAL-20070705.jar`:这是Apache POI的核心库文件...

    POI的EXCEL导出,自动换行

    对于Excel文件的操作主要通过两个核心API来完成:`HSSFWorkbook`和`XSSFWorkbook`,分别对应于旧版Excel(.xls)和新版Excel(.xlsx)文件格式。 #### 二、环境准备 为了能够在项目中使用Apache POI,首先需要添加...

    POI操作Excel文档,帮助文档

    ### POI操作Excel文档知识点详解 #### 一、POI简介 Apache POI 是 Apache 软件基金会的开源项目之一,它主要提供了一系列用于处理 Microsoft Office 文档的 Java API。POI 支持多种 Office 文件格式,其中较为成熟...

    spring3.2.5 MVC Poi3.9操作excel批量导入

    总之,"spring3.2.5 MVC Poi3.9操作excel批量导入"是一个涵盖了Web开发、数据处理和文件操作的综合技术主题。结合Spring MVC的灵活性、Apache POI的强大文件处理能力以及Maven的项目管理,开发者可以构建出强大且...

    Springboot+Poi实现Excel的导入导出

    POI库提供了HSSF(用于处理老版本的.XLS格式)和XSSF(用于处理新版本的.XLSX格式)组件,可以进行创建、读取、修改Excel工作簿、工作表、单元格等操作。 在本项目中,Spring Boot结合MyBatis和POI,实现了一个完整...

    poi读取excel文件

    在Java编程环境中,Apache POI库是一个非常重要的工具,它允许开发者读取、写入以及修改...总的来说,Apache POI是Java处理Excel文件的强大工具,通过合理利用提供的库和源码示例,可以有效地读取和操作Excel数据。

    java的POI操作Excel文件.pdf

    总的来说,Java的Apache POI库提供了丰富的功能,使开发者能够方便地操作Excel文件。在处理复杂的Excel任务时,理解库的内部机制和常见问题的解决方案至关重要。通过不断学习和实践,我们可以更高效地利用POI来满足...

    poi解析excel文件

    Apache POI 是一个开源项目,专门用于处理Microsoft Office格式的文件,如Excel、Word和PowerPoint。...通过理解其核心组件和API,你可以有效地操作Excel数据,进行数据分析、数据导入导出等各种任务。

Global site tag (gtag.js) - Google Analytics