文档章节

项目使用excel模板写入图片总结

abcijkxyz
 abcijkxyz
发布于 2016/07/08 16:29
字数 571
阅读 4
收藏 0
导出excel的问题,导出多个sheet使用模板方式还是api方式,不知道什么方式更好点
     讨论结果:
     1)使用模板方式,对于多余的sheel进行删除。
     2)建议在导出的过程中,将导出按钮灰掉,不让其操作。
     3)介绍使用jconsole监控导出性能,防止后期出现性能问题。
     4)jxl只支持png格式的图片,需要通过ImageIO对图片进行转换
     遇到问题:
     1)poi在向模板中插入图片的时候,如果模板存在批注,生产的文件会提示数据丢失,并且不能编译。
     2)如何将多张图片放在同一个单元格中显示。
样例代码:
package com.test;


import java.awt.image.BufferedImage;
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;


import javax.imageio.ImageIO;


import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFCellStyle;
import org.apache.poi.hssf.usermodel.HSSFClientAnchor;
import org.apache.poi.hssf.usermodel.HSSFFont;
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.hssf.util.HSSFColor;


public class ExcelPoi {


@SuppressWarnings("deprecation")
public void exportExcel() {
String realpath = "关注本地人员导出模板.xls";
try {
HSSFWorkbook workbook = new HSSFWorkbook(new FileInputStream(realpath));
File target = new File("test1.xls");
HSSFSheet sheet = workbook.getSheet("fang");
HSSFCellStyle style = this.getStyle(workbook);


HSSFRow row = sheet.getRow(1);
HSSFCell cell = row.getCell((short) 2);
cell.setCellStyle(style);
cell.setCellValue("xx");
/**/

// 行高
//row = sheet.getRow(59);
//row.setHeight((short)5000);

BufferedImage bufferImg = null;
BufferedImage bufferImg1 = null;
ByteArrayOutputStream byteArrayOut = new ByteArrayOutputStream();
ByteArrayOutputStream byteArrayOut1 = new ByteArrayOutputStream();
bufferImg = ImageIO.read(new File("1.jpg"));
bufferImg1 = ImageIO.read(new File("2.jpg"));
ImageIO.write(bufferImg, "jpg", byteArrayOut);
ImageIO.write(bufferImg1, "jpg", byteArrayOut1);

HSSFPatriarch patriarch = sheet.createDrawingPatriarch();
HSSFClientAnchor anchor = new HSSFClientAnchor(0, 0, 174, 190, (short) 2, 59, (short) 2, 59);
//HSSFClientAnchor anchor1 = new HSSFClientAnchor(174, 0, 350, 160, (short) 2, 59, (short) 2, 59);
//anchor1.setAnchorType(2);
patriarch.createPicture(anchor, workbook.addPicture(byteArrayOut.toByteArray(),HSSFWorkbook.PICTURE_TYPE_JPEG));
//patriarch.createPicture(anchor1, workbook.addPicture(byteArrayOut1.toByteArray(),HSSFWorkbook.PICTURE_TYPE_JPEG));


//byteArrayOut.close();
//byteArrayOut1.close();

//workbook.removeSheetAt(2);
FileOutputStream fos = new FileOutputStream(target);
workbook.write(fos);
fos.flush();
fos.close();



} catch (Exception e) {
e.printStackTrace();
}


System.out.println("成功导出Excel!!!!");
}


public HSSFCellStyle getStyle(HSSFWorkbook workbook) {
//      设置字体; 
HSSFFont font = workbook.createFont();
//设置字体大小; 
font.setFontHeightInPoints((short) 10);
//设置字体名字; 
font.setFontName("仿宋_GB2312");
//font.setItalic(true); 
//font.setStrikeout(true); 
//      设置样式; 
HSSFCellStyle style = workbook.createCellStyle();
//设置底边框; 
style.setBorderBottom(HSSFCellStyle.BORDER_THIN);
//设置底边框颜色; 
style.setBottomBorderColor(HSSFColor.BLACK.index);
//设置左边框; 
style.setBorderLeft(HSSFCellStyle.BORDER_THIN);
//设置左边框颜色; 
style.setLeftBorderColor(HSSFColor.BLACK.index);
//设置右边框; 
style.setBorderRight(HSSFCellStyle.BORDER_THIN);
//设置右边框颜色; 
style.setRightBorderColor(HSSFColor.BLACK.index);
//设置顶边框; 
style.setBorderTop(HSSFCellStyle.BORDER_THIN);
//设置顶边框颜色; 
style.setTopBorderColor(HSSFColor.BLACK.index);
//在样式用应用设置的字体; 
style.setFont(font);
//设置自动换行; 
style.setWrapText(false);
//设置水平对齐的样式为居中对齐; 
style.setAlignment(HSSFCellStyle.ALIGN_LEFT);
//设置垂直对齐的样式为居中对齐; 
style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);
return style;
}


public static void main(String[] args) {
ExcelPoi excelpoi = new ExcelPoi();
excelpoi.exportExcel();
}
}

本文转载自:http://blog.csdn.net/yuwenruli/article/details/7815352

共有 人打赏支持
abcijkxyz
粉丝 63
博文 6196
码字总数 1876
作品 0
深圳
项目经理
私信 提问
Java中用Apache POI生成excel和word文档

版权声明:本文为LZUGIS原创文章,未经允许不得转载。 https://blog.csdn.net/GISShiXiSheng/article/details/46609525 概述: 最近在做项目的过程中遇到了excel的数据导出和word的图文表报告...

Airship
09/12
0
0
ireport报表中无法识别的生僻字的使用图片代替

在利用ireport输出报表的时候,有些生僻字无法处理,报的异常为--->数组下标越界 在网上查找了相关资料,没有找到解决办法,实在没辙了,只能使用图片代替了... 步骤:(假设在模板中放入生僻字的是...

文文1
2016/07/19
33
0
Crab2Died/Excel4J

Excel4J v2.x 一. v2.x新特性 Excel读取支持部分类型转换了(如转为Integer,Long,Date(部分)等) v2.0.0之前只能全部内容转为String Excel支持非注解读取Excel内容了,内容存于对象内 现在支持导...

Crab2Died
2017/06/11
0
0
Go 语言读写 Excel 文档

Excelize 是 Golang 编写的一个用来操作 Office Excel 文档类库,基于微软的 Office OpenXML 标准。可以使用它来读取、写入 XLSX 文件。相比较其他的开源类库,Excelize 支持写入原本带有图片...

xurime
2017/05/11
0
0
使用POI操作Excel的几点注意事项

首先说说现在我所知道的Java编辑Excel文件的两大开源工具: jakarta POI和JavaExcel API(简称JXL),这两套工具我都试用了一这段时间,感觉各有优劣吧。POI在某些细节有些小Bug并且不支持写...

红薯
2008/12/05
2.6K
2

没有更多内容

加载失败,请刷新页面

加载更多

ArrayList的实现原理以及实现线程安全

一、ArrayList概述 ArrayList是基于数组实现的,是一个动态的数字,可以自动扩容。 ArrayList不是线程安全的,效率比较高,只能用于单线程的环境中,在多线程环境中可以使用Collections.syn...

一看就喷亏的小猿
22分钟前
1
0
Netty 备录 (一)

入职新公司不久,修修补补1个月的bug,来了点实战性的技术---基于netty即时通信 还好之前对socket有所使用及了解,入手netty应该不是很难吧,好吧,的确有点难,刚看这玩意的时候,可能都不知道哪里...

_大侠__
昨天
4
0
Django简单介绍和用户访问流程

Python下有许多款不同的 Web 框架。Django是重量级选手中最有代表性的一位。许多成功的网站和APP都基于Django。 Django是一个开放源代码的Web应用框架,由Python写成。 Django遵守BSD版权,初...

枫叶云
昨天
8
0
EOS错误代码及中文释义

本文集汇总了EOS区块链常见错误代码及其含义,完整错误代码集请查看 EOS错误代码集 - 汇智网 EOS错误代码列表如下, <table class="table table-striped"> <thead> <tr><th>错误代码</th><t......

汇智网教程
昨天
5
0
Spring Cloud Stream消费失败后的处理策略(四):重新入队(RabbitMQ)

应用场景 之前我们已经通过《Spring Cloud Stream消费失败后的处理策略(一):自动重试》一文介绍了Spring Cloud Stream默认的消息重试功能。本文将介绍RabbitMQ的binder提供的另外一种重试...

程序猿DD
昨天
5
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部