利用POI在Excel文档任意单元格写入数据
2014-04-15 09:29
543 查看
/article/3873804.html
在我们实际的开发中,表现层的解决方案虽然有多样,但是IE浏览器已成为最多人使用的浏览器,因为大家都用Windows。在企业办公系统中,常常有客户这样子要求:你要把我们的报表直接用Excel打开(电信系统、银行系统)。或者是:我们已经习惯用Excel打印。
Apache的Jakata项目的POI子项目,目前比较成熟的是HSSF接口,处理MSExcel对象。它不象我们仅仅是用csv生成的没有格式的可以由Excel转换的东西,而是真正的Excel对象,你可以控制一些属性如sheet,cell等等。
首先,理解一下一个Excel的文件的组织形式,一个Excel文件对应于一个workbook(HSSFWorkbook),一个workbook可以有多个sheet(HSSFSheet)组成,一个sheet是由多个row(HSSFRow)组成,一个row是由多个cell(HSSFCell)组成。
那么,如何利用POI在Excel文档任意单元格写入数据?最近做了个项目,一个人研究了下,现在把代码拿出来和大家分享下!不足之处请前辈们多多指教!
Reportbuilder 代码
import java.awt.image.BufferedImage;
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import javax.imageio.ImageIO;
import javax.imageio.stream.ImageInputStream;
import org.apache.poi.hssf.record.PageBreakRecord.Break;
import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFClientAnchor;
import org.apache.poi.hssf.usermodel.HSSFPatriarch;
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.poifs.filesystem.POIFSFileSystem;
public class ReportBuilder
{
public static String outFile_Erro = "Load Template Erro,文件加载失败!!";
FileOutputStream fileOutputStream = null;
HSSFWorkbook workbook = null;
HSSFSheet sheet = null;
HSSFPatriarch patriarch = null;
/**
* @用途:加载一个已经存在的模板,将生成的内容保存到 workbook中
* @参数:String templateFile:指索要加载的模板的路径,如:"C:/Tamplates/texting-1.xls"
* @用法:templateFile: String templateFile_Name1 = "C:/Tamplates/texting-1.xls"
* @author Yangcl
*/
public void loadTemplate(String templateURL)
{
// TODO Auto-generated method stub
boolean a = templateURL.trim().indexOf(".xls") == -1;
boolean b = templateURL.trim().indexOf(".XLS") == -1;
// boolean c = templateURL.trim().indexOf(".xlsx") == -1;
// boolean d = templateURL.trim().indexOf(".XLSX") == -1;
if(templateURL == null || templateURL.trim().equals("") )
{
//文件不能为空提示
System.out.println("文件不能为空提示");
}
else if(a&&b)// && c&&d)
{
System.out.println("文件格式不正确!");
}
else{
try{
FileInputStream templateFile_Input = new FileInputStream(templateURL);
POIFSFileSystem fs = new POIFSFileSystem(templateFile_Input);
workbook = new HSSFWorkbook(fs);
sheet = workbook.getSheetAt(0);
System.out.println("========"+templateURL+"文件加载已完成========");
}catch(Exception e){
System.err.println(outFile_Erro);
}
}
}
/**
* 写入非图片格式信息
* @描述:这是一个实体类,提供了相应的接口,用于操作Excel,在任意坐标处写入数据。
* @参数:String newContent:你要输入的内容
* int beginRow :行坐标,Excel从 0 算起
* int beginCol :列坐标,Excel从 0 算起
* @author Yangcl
*/
public void writeInTemplate( String newContent, int beginRow, int beginCell)
{
HSSFRow row = sheet.getRow(beginRow);
if(null == row ){
//如果不做空判断,你必须让你的模板文件画好边框,beginRow和beginCell必须在边框最大值以内
//否则会出现空指针异常
row = sheet.createRow(beginRow);
}
HSSFCell cell = row.getCell(beginCell);
if(null == cell){
cell = row.createCell(beginCell);
}
//设置存入内容为字符串
cell.setCellType(HSSFCell.CELL_TYPE_STRING);
//向单元格中放入值
cell.setCellValue(newContent);
}
/**
* 写入图片格式信息
* @描述:这是一个实体类,提供了相应的接口,用于操作Excel,在任意坐标处写入数据。
* @参数:
* String imageFileURL:他接受一个外界传入的图片路径,图片以 *.jpeg 形式存在。
*
* @用法:
* ReportBuilder twi = new ReportBuilder();
* String imageFileURL = "D:/workspace/Tamplates/1.jpeg";
* twi.writeInTemplate(imageFileURL , 0,0, 0, 0, (short)6, 5, (short)8, 8);
*
* @param dx1 :第一个cell开始的X坐标
* @param dy1 :第一个cell开始的Y坐标
* @param dx2 :第二个cell开始的X坐标
* @param dy2 :第二个cell开始的Y坐标
* @param col1 :图片的左上角放在第几个列cell (the column(o based); of the first cell)
* @param row1 :图片的左上角放在第几个行cell (the row(o based); of the first cell)
* @param col2 :图片的右下角放在第几个列cell (the column(o based); of the second cell)
* @param row2 :图片的右下角放在第几个行cell (the row(o based); of the second cell)
*
* @author Yangcl
*/
public void writeInTemplate(String imageFileURL , int dx1, int dy1, int dx2, int dy2, short col1, int row1, short col2, int row2 )
{
BufferedImage bufferImage = null;
//写入图片格式信息
try
{
ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
//先把读入的图片放到第一个 ByteArrayOutputStream 中,用于产生ByteArray
File fileImage = new File(imageFileURL);
bufferImage = ImageIO.read(fileImage);
ImageIO.write(bufferImage, "JPG", byteArrayOutputStream);
System.out.println("ImageIO 写入完成");
//准备插入图片
HSSFPatriarch patriarch = sheet.createDrawingPatriarch();
HSSFClientAnchor anchor = new HSSFClientAnchor(dx1, dy1, dx2, dy2, col1, row1, col2, row2);
//插入图片
byte[] pictureData = byteArrayOutputStream.toByteArray();
int pictureFormat = HSSFWorkbook.PICTURE_TYPE_JPEG;
int pictureIndex = workbook.addPicture(pictureData, pictureFormat);
patriarch.createPicture(anchor, pictureIndex);
}catch(Exception e){
e.printStackTrace();
System.out.println("IO Erro:" + e.getMessage());
}finally
{
if(fileOutputStream != null)
{
try{
fileOutputStream.close();
}catch(IOException io){
io.printStackTrace();
}
}
}
}
/**
* 写入图片格式信息
* @描述:这是一个实体类,提供了相应的接口,用于操作Excel,在任意坐标处写入数据。
* @参数:
* ImageInputStream imageInputStream:他接受一个外界传入的图片流,图片以流形式存在。
*
* @用法:
*
*
*
*
* @param dx1 :第一个cell开始的X坐标
* @param dy1 :第一个cell开始的Y坐标
* @param dx2 :第二个cell开始的X坐标
* @param dy2 :第二个cell开始的Y坐标
* @param col1 :图片的左上角放在第几个列cell (the column(o based); of the first cell)
* @param row1 :图片的左上角放在第几个行cell (the row(o based); of the first cell)
* @param col2 :图片的右下角放在第几个列cell (the column(o based); of the second cell)
* @param row2 :图片的右下角放在第几个行cell (the row(o based); of the second cell)
*
* @author Yangcl
*/
public void writeInTemplate(ImageInputStream imageInputStream , int dx1, int dy1, int dx2, int dy2, short col1, int row1, short col2, int row2 )
{
BufferedImage bufferImage = null;
//写入图片格式信息
try
{
ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
//先把读入的图片放到一个 ByteArrayOutputStream 中,用于产生ByteArray
bufferImage = ImageIO.read(imageInputStream);
ImageIO.write(bufferImage, "JPG", byteArrayOutputStream);
System.out.println("ImageIO 写入完成");
//准备插入图片
HSSFPatriarch patriarch = sheet.createDrawingPatriarch();
HSSFClientAnchor anchor = new HSSFClientAnchor(dx1, dy1, dx2, dy2, col1, row1, col2, row2);
//插入图片
byte[] pictureData = byteArrayOutputStream.toByteArray();
int pictureFormat = HSSFWorkbook.PICTURE_TYPE_JPEG;
int pictureIndex = workbook.addPicture(pictureData, pictureFormat);
patriarch.createPicture(anchor, pictureIndex);
}catch(Exception e){
e.printStackTrace();
System.out.println("IO Erro:" + e.getMessage());
}finally
{
if(fileOutputStream != null)
{
try{
fileOutputStream.close();
}catch(IOException io){
io.printStackTrace();
}
}
}
}
/**
* 保存模板
* @描述:这个方法用于保存workbook(工作薄)中的内容,并写入到一个Excel文件中
* @参数:String templateFile:取得已经保存的类模板 路径名称
* @用法:templateFile:String templateFile_Name1 = "C:/Tamplates/texting-1.xls"
* TemplateAdapter ta = new TemplateAdapter();
* ta.SaveTemplate(templateFile_Name1);
* @param templateFile
*/
public void SaveTemplate(String templateFile)
{
try{
//建立输出流
fileOutputStream = new FileOutputStream(templateFile);
workbook.write(fileOutputStream);
}catch(Exception e){
e.printStackTrace();
System.out.println("IO Erro" + e.getMessage());
}finally
{
if(fileOutputStream != null)
{
try{
fileOutputStream.close();
}catch(IOException io){
io.printStackTrace();
}
}
}
}
}
这段代码是完整的。我开始找了很久关于如何利用POI在Excel文档任意单元格写入数据的文章,从而实现一个以面向服务为目标的报表系统,但很遗憾,在国内的网站上没有找到。而且介绍的比较基础,对于急需使用POI,但又没有时间仔细研究的人来说,难过急了。上面的代码有比较详细的注释,相信大家看的懂。如果您要转载这篇文章,请注明出处。开源万岁~祝您成功。文档依赖的两个
jar包:commons-codec-1.5.jar和poi-3.8-20120326.jar见附件。这字体真让人蛋疼菊紧!
在我们实际的开发中,表现层的解决方案虽然有多样,但是IE浏览器已成为最多人使用的浏览器,因为大家都用Windows。在企业办公系统中,常常有客户这样子要求:你要把我们的报表直接用Excel打开(电信系统、银行系统)。或者是:我们已经习惯用Excel打印。
Apache的Jakata项目的POI子项目,目前比较成熟的是HSSF接口,处理MSExcel对象。它不象我们仅仅是用csv生成的没有格式的可以由Excel转换的东西,而是真正的Excel对象,你可以控制一些属性如sheet,cell等等。
首先,理解一下一个Excel的文件的组织形式,一个Excel文件对应于一个workbook(HSSFWorkbook),一个workbook可以有多个sheet(HSSFSheet)组成,一个sheet是由多个row(HSSFRow)组成,一个row是由多个cell(HSSFCell)组成。
那么,如何利用POI在Excel文档任意单元格写入数据?最近做了个项目,一个人研究了下,现在把代码拿出来和大家分享下!不足之处请前辈们多多指教!
Reportbuilder 代码
import java.awt.image.BufferedImage;
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import javax.imageio.ImageIO;
import javax.imageio.stream.ImageInputStream;
import org.apache.poi.hssf.record.PageBreakRecord.Break;
import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFClientAnchor;
import org.apache.poi.hssf.usermodel.HSSFPatriarch;
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.poifs.filesystem.POIFSFileSystem;
public class ReportBuilder
{
public static String outFile_Erro = "Load Template Erro,文件加载失败!!";
FileOutputStream fileOutputStream = null;
HSSFWorkbook workbook = null;
HSSFSheet sheet = null;
HSSFPatriarch patriarch = null;
/**
* @用途:加载一个已经存在的模板,将生成的内容保存到 workbook中
* @参数:String templateFile:指索要加载的模板的路径,如:"C:/Tamplates/texting-1.xls"
* @用法:templateFile: String templateFile_Name1 = "C:/Tamplates/texting-1.xls"
* @author Yangcl
*/
public void loadTemplate(String templateURL)
{
// TODO Auto-generated method stub
boolean a = templateURL.trim().indexOf(".xls") == -1;
boolean b = templateURL.trim().indexOf(".XLS") == -1;
// boolean c = templateURL.trim().indexOf(".xlsx") == -1;
// boolean d = templateURL.trim().indexOf(".XLSX") == -1;
if(templateURL == null || templateURL.trim().equals("") )
{
//文件不能为空提示
System.out.println("文件不能为空提示");
}
else if(a&&b)// && c&&d)
{
System.out.println("文件格式不正确!");
}
else{
try{
FileInputStream templateFile_Input = new FileInputStream(templateURL);
POIFSFileSystem fs = new POIFSFileSystem(templateFile_Input);
workbook = new HSSFWorkbook(fs);
sheet = workbook.getSheetAt(0);
System.out.println("========"+templateURL+"文件加载已完成========");
}catch(Exception e){
System.err.println(outFile_Erro);
}
}
}
/**
* 写入非图片格式信息
* @描述:这是一个实体类,提供了相应的接口,用于操作Excel,在任意坐标处写入数据。
* @参数:String newContent:你要输入的内容
* int beginRow :行坐标,Excel从 0 算起
* int beginCol :列坐标,Excel从 0 算起
* @author Yangcl
*/
public void writeInTemplate( String newContent, int beginRow, int beginCell)
{
HSSFRow row = sheet.getRow(beginRow);
if(null == row ){
//如果不做空判断,你必须让你的模板文件画好边框,beginRow和beginCell必须在边框最大值以内
//否则会出现空指针异常
row = sheet.createRow(beginRow);
}
HSSFCell cell = row.getCell(beginCell);
if(null == cell){
cell = row.createCell(beginCell);
}
//设置存入内容为字符串
cell.setCellType(HSSFCell.CELL_TYPE_STRING);
//向单元格中放入值
cell.setCellValue(newContent);
}
/**
* 写入图片格式信息
* @描述:这是一个实体类,提供了相应的接口,用于操作Excel,在任意坐标处写入数据。
* @参数:
* String imageFileURL:他接受一个外界传入的图片路径,图片以 *.jpeg 形式存在。
*
* @用法:
* ReportBuilder twi = new ReportBuilder();
* String imageFileURL = "D:/workspace/Tamplates/1.jpeg";
* twi.writeInTemplate(imageFileURL , 0,0, 0, 0, (short)6, 5, (short)8, 8);
*
* @param dx1 :第一个cell开始的X坐标
* @param dy1 :第一个cell开始的Y坐标
* @param dx2 :第二个cell开始的X坐标
* @param dy2 :第二个cell开始的Y坐标
* @param col1 :图片的左上角放在第几个列cell (the column(o based); of the first cell)
* @param row1 :图片的左上角放在第几个行cell (the row(o based); of the first cell)
* @param col2 :图片的右下角放在第几个列cell (the column(o based); of the second cell)
* @param row2 :图片的右下角放在第几个行cell (the row(o based); of the second cell)
*
* @author Yangcl
*/
public void writeInTemplate(String imageFileURL , int dx1, int dy1, int dx2, int dy2, short col1, int row1, short col2, int row2 )
{
BufferedImage bufferImage = null;
//写入图片格式信息
try
{
ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
//先把读入的图片放到第一个 ByteArrayOutputStream 中,用于产生ByteArray
File fileImage = new File(imageFileURL);
bufferImage = ImageIO.read(fileImage);
ImageIO.write(bufferImage, "JPG", byteArrayOutputStream);
System.out.println("ImageIO 写入完成");
//准备插入图片
HSSFPatriarch patriarch = sheet.createDrawingPatriarch();
HSSFClientAnchor anchor = new HSSFClientAnchor(dx1, dy1, dx2, dy2, col1, row1, col2, row2);
//插入图片
byte[] pictureData = byteArrayOutputStream.toByteArray();
int pictureFormat = HSSFWorkbook.PICTURE_TYPE_JPEG;
int pictureIndex = workbook.addPicture(pictureData, pictureFormat);
patriarch.createPicture(anchor, pictureIndex);
}catch(Exception e){
e.printStackTrace();
System.out.println("IO Erro:" + e.getMessage());
}finally
{
if(fileOutputStream != null)
{
try{
fileOutputStream.close();
}catch(IOException io){
io.printStackTrace();
}
}
}
}
/**
* 写入图片格式信息
* @描述:这是一个实体类,提供了相应的接口,用于操作Excel,在任意坐标处写入数据。
* @参数:
* ImageInputStream imageInputStream:他接受一个外界传入的图片流,图片以流形式存在。
*
* @用法:
*
*
*
*
* @param dx1 :第一个cell开始的X坐标
* @param dy1 :第一个cell开始的Y坐标
* @param dx2 :第二个cell开始的X坐标
* @param dy2 :第二个cell开始的Y坐标
* @param col1 :图片的左上角放在第几个列cell (the column(o based); of the first cell)
* @param row1 :图片的左上角放在第几个行cell (the row(o based); of the first cell)
* @param col2 :图片的右下角放在第几个列cell (the column(o based); of the second cell)
* @param row2 :图片的右下角放在第几个行cell (the row(o based); of the second cell)
*
* @author Yangcl
*/
public void writeInTemplate(ImageInputStream imageInputStream , int dx1, int dy1, int dx2, int dy2, short col1, int row1, short col2, int row2 )
{
BufferedImage bufferImage = null;
//写入图片格式信息
try
{
ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
//先把读入的图片放到一个 ByteArrayOutputStream 中,用于产生ByteArray
bufferImage = ImageIO.read(imageInputStream);
ImageIO.write(bufferImage, "JPG", byteArrayOutputStream);
System.out.println("ImageIO 写入完成");
//准备插入图片
HSSFPatriarch patriarch = sheet.createDrawingPatriarch();
HSSFClientAnchor anchor = new HSSFClientAnchor(dx1, dy1, dx2, dy2, col1, row1, col2, row2);
//插入图片
byte[] pictureData = byteArrayOutputStream.toByteArray();
int pictureFormat = HSSFWorkbook.PICTURE_TYPE_JPEG;
int pictureIndex = workbook.addPicture(pictureData, pictureFormat);
patriarch.createPicture(anchor, pictureIndex);
}catch(Exception e){
e.printStackTrace();
System.out.println("IO Erro:" + e.getMessage());
}finally
{
if(fileOutputStream != null)
{
try{
fileOutputStream.close();
}catch(IOException io){
io.printStackTrace();
}
}
}
}
/**
* 保存模板
* @描述:这个方法用于保存workbook(工作薄)中的内容,并写入到一个Excel文件中
* @参数:String templateFile:取得已经保存的类模板 路径名称
* @用法:templateFile:String templateFile_Name1 = "C:/Tamplates/texting-1.xls"
* TemplateAdapter ta = new TemplateAdapter();
* ta.SaveTemplate(templateFile_Name1);
* @param templateFile
*/
public void SaveTemplate(String templateFile)
{
try{
//建立输出流
fileOutputStream = new FileOutputStream(templateFile);
workbook.write(fileOutputStream);
}catch(Exception e){
e.printStackTrace();
System.out.println("IO Erro" + e.getMessage());
}finally
{
if(fileOutputStream != null)
{
try{
fileOutputStream.close();
}catch(IOException io){
io.printStackTrace();
}
}
}
}
}
import java.awt.image.BufferedImage; import java.io.ByteArrayOutputStream; import java.io.File; import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.IOException; import javax.imageio.ImageIO; import javax.imageio.stream.ImageInputStream; import org.apache.poi.hssf.record.PageBreakRecord.Break; import org.apache.poi.hssf.usermodel.HSSFCell; import org.apache.poi.hssf.usermodel.HSSFClientAnchor; import org.apache.poi.hssf.usermodel.HSSFPatriarch; 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.poifs.filesystem.POIFSFileSystem; public class ReportBuilder { public static String outFile_Erro = "Load Template Erro,文件加载失败!!"; FileOutputStream fileOutputStream = null; HSSFWorkbook workbook = null; HSSFSheet sheet = null; HSSFPatriarch patriarch = null; /** * @用途:加载一个已经存在的模板,将生成的内容保存到 workbook中 * @参数:String templateFile:指索要加载的模板的路径,如:"C:/Tamplates/texting-1.xls" * @用法:templateFile: String templateFile_Name1 = "C:/Tamplates/texting-1.xls" * @author Yangcl */ public void loadTemplate(String templateURL) { // TODO Auto-generated method stub boolean a = templateURL.trim().indexOf(".xls") == -1; boolean b = templateURL.trim().indexOf(".XLS") == -1; // boolean c = templateURL.trim().indexOf(".xlsx") == -1; // boolean d = templateURL.trim().indexOf(".XLSX") == -1; if(templateURL == null || templateURL.trim().equals("") ) { //文件不能为空提示 System.out.println("文件不能为空提示"); } else if(a&&b)// && c&&d) { System.out.println("文件格式不正确!"); } else{ try{ FileInputStream templateFile_Input = new FileInputStream(templateURL); POIFSFileSystem fs = new POIFSFileSystem(templateFile_Input); workbook = new HSSFWorkbook(fs); sheet = workbook.getSheetAt(0); System.out.println("========"+templateURL+"文件加载已完成========"); }catch(Exception e){ System.err.println(outFile_Erro); } } } /** * 写入非图片格式信息 * @描述:这是一个实体类,提供了相应的接口,用于操作Excel,在任意坐标处写入数据。 * @参数:String newContent:你要输入的内容 * int beginRow :行坐标,Excel从 0 算起 * int beginCol :列坐标,Excel从 0 算起 * @author Yangcl */ public void writeInTemplate( String newContent, int beginRow, int beginCell) { HSSFRow row = sheet.getRow(beginRow); if(null == row ){ //如果不做空判断,你必须让你的模板文件画好边框,beginRow和beginCell必须在边框最大值以内 //否则会出现空指针异常 row = sheet.createRow(beginRow); } HSSFCell cell = row.getCell(beginCell); if(null == cell){ cell = row.createCell(beginCell); } //设置存入内容为字符串 cell.setCellType(HSSFCell.CELL_TYPE_STRING); //向单元格中放入值 cell.setCellValue(newContent); } /** * 写入图片格式信息 * @描述:这是一个实体类,提供了相应的接口,用于操作Excel,在任意坐标处写入数据。 * @参数: * String imageFileURL:他接受一个外界传入的图片路径,图片以 *.jpeg 形式存在。 * * @用法: * ReportBuilder twi = new ReportBuilder(); * String imageFileURL = "D:/workspace/Tamplates/1.jpeg"; * twi.writeInTemplate(imageFileURL , 0,0, 0, 0, (short)6, 5, (short)8, 8); * * @param dx1 :第一个cell开始的X坐标 * @param dy1 :第一个cell开始的Y坐标 * @param dx2 :第二个cell开始的X坐标 * @param dy2 :第二个cell开始的Y坐标 * @param col1 :图片的左上角放在第几个列cell (the column(o based); of the first cell) * @param row1 :图片的左上角放在第几个行cell (the row(o based); of the first cell) * @param col2 :图片的右下角放在第几个列cell (the column(o based); of the second cell) * @param row2 :图片的右下角放在第几个行cell (the row(o based); of the second cell) * * @author Yangcl */ public void writeInTemplate(String imageFileURL , int dx1, int dy1, int dx2, int dy2, short col1, int row1, short col2, int row2 ) { BufferedImage bufferImage = null; //写入图片格式信息 try { ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream(); //先把读入的图片放到第一个 ByteArrayOutputStream 中,用于产生ByteArray File fileImage = new File(imageFileURL); bufferImage = ImageIO.read(fileImage); ImageIO.write(bufferImage, "JPG", byteArrayOutputStream); System.out.println("ImageIO 写入完成"); //准备插入图片 HSSFPatriarch patriarch = sheet.createDrawingPatriarch(); HSSFClientAnchor anchor = new HSSFClientAnchor(dx1, dy1, dx2, dy2, col1, row1, col2, row2); //插入图片 byte[] pictureData = byteArrayOutputStream.toByteArray(); int pictureFormat = HSSFWorkbook.PICTURE_TYPE_JPEG; int pictureIndex = workbook.addPicture(pictureData, pictureFormat); patriarch.createPicture(anchor, pictureIndex); }catch(Exception e){ e.printStackTrace(); System.out.println("IO Erro:" + e.getMessage()); }finally { if(fileOutputStream != null) { try{ fileOutputStream.close(); }catch(IOException io){ io.printStackTrace(); } } } } /** * 写入图片格式信息 * @描述:这是一个实体类,提供了相应的接口,用于操作Excel,在任意坐标处写入数据。 * @参数: * ImageInputStream imageInputStream:他接受一个外界传入的图片流,图片以流形式存在。 * * @用法: * * * * * @param dx1 :第一个cell开始的X坐标 * @param dy1 :第一个cell开始的Y坐标 * @param dx2 :第二个cell开始的X坐标 * @param dy2 :第二个cell开始的Y坐标 * @param col1 :图片的左上角放在第几个列cell (the column(o based); of the first cell) * @param row1 :图片的左上角放在第几个行cell (the row(o based); of the first cell) * @param col2 :图片的右下角放在第几个列cell (the column(o based); of the second cell) * @param row2 :图片的右下角放在第几个行cell (the row(o based); of the second cell) * * @author Yangcl */ public void writeInTemplate(ImageInputStream imageInputStream , int dx1, int dy1, int dx2, int dy2, short col1, int row1, short col2, int row2 ) { BufferedImage bufferImage = null; //写入图片格式信息 try { ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream(); //先把读入的图片放到一个 ByteArrayOutputStream 中,用于产生ByteArray bufferImage = ImageIO.read(imageInputStream); ImageIO.write(bufferImage, "JPG", byteArrayOutputStream); System.out.println("ImageIO 写入完成"); //准备插入图片 HSSFPatriarch patriarch = sheet.createDrawingPatriarch(); HSSFClientAnchor anchor = new HSSFClientAnchor(dx1, dy1, dx2, dy2, col1, row1, col2, row2); //插入图片 byte[] pictureData = byteArrayOutputStream.toByteArray(); int pictureFormat = HSSFWorkbook.PICTURE_TYPE_JPEG; int pictureIndex = workbook.addPicture(pictureData, pictureFormat); patriarch.createPicture(anchor, pictureIndex); }catch(Exception e){ e.printStackTrace(); System.out.println("IO Erro:" + e.getMessage()); }finally { if(fileOutputStream != null) { try{ fileOutputStream.close(); }catch(IOException io){ io.printStackTrace(); } } } } /** * 保存模板 * @描述:这个方法用于保存workbook(工作薄)中的内容,并写入到一个Excel文件中 * @参数:String templateFile:取得已经保存的类模板 路径名称 * @用法:templateFile:String templateFile_Name1 = "C:/Tamplates/texting-1.xls" * TemplateAdapter ta = new TemplateAdapter(); * ta.SaveTemplate(templateFile_Name1); * @param templateFile */ public void SaveTemplate(String templateFile) { try{ //建立输出流 fileOutputStream = new FileOutputStream(templateFile); workbook.write(fileOutputStream); }catch(Exception e){ e.printStackTrace(); System.out.println("IO Erro" + e.getMessage()); }finally { if(fileOutputStream != null) { try{ fileOutputStream.close(); }catch(IOException io){ io.printStackTrace(); } } } } }
这段代码是完整的。我开始找了很久关于如何利用POI在Excel文档任意单元格写入数据的文章,从而实现一个以面向服务为目标的报表系统,但很遗憾,在国内的网站上没有找到。而且介绍的比较基础,对于急需使用POI,但又没有时间仔细研究的人来说,难过急了。上面的代码有比较详细的注释,相信大家看的懂。如果您要转载这篇文章,请注明出处。开源万岁~祝您成功。文档依赖的两个
jar包:commons-codec-1.5.jar和poi-3.8-20120326.jar见附件。这字体真让人蛋疼菊紧!
相关文章推荐
- Python Excel 导入导出【转】
- #import,#pragma comment, loadLibrary" 三种引入dll的方式都分别在什么时候使用
- Android程序使用代码的安装和卸载
- 初识spring boot maven管理--属性文件配置
- 二项堆(二)之 C++的实现
- delphi7 dbgrid中加入COMBOBOX
- EL 表达式小结 (Express Language)
- 快速查询本机IP
- 快速查询本机IP 分类: windows常用小技巧 2014-04-15 09:28 138人阅读 评论(0) 收藏
- ORA-28001: the password has expired解决方法
- NSRange 用法
- 异步获取的表单数据后台程序没有获取的一种情况及其解决方法
- TCP/IP协议详解笔记——ARP协议和RARP协议
- 【DOM编程艺术】动态创建标记(签)---创建和插入节点
- Where am I? You need to setup your server names in class.config.php $_SERVER['HTTP_HOST'] reported
- 健康就是一切
- onConfigurationChanged
- Java float精度计算的问题,截取小数点后两位
- 文件属性信息的获取与更改 WIN32_FIND_DATA
- iOS开源项目之日志框架CocoaLumberjack