当前位置: 首页 > news >正文

excel导出图片---HSSFWorkbook--SXSSFWorkbook

1 概述

平时在工作中,excel导出图片经常会用到,但奈何HSSFWorkbook导出数据数量有限制问题,所以企业里大多都用SXSSFWorkbook格式,很少用HSSFWorkbook。所以今天以这两种格式分别记录下,图片的导出过程。

2 HSSFWorkbook

 @Testpublic void excelImageTestHSSFWorkbook1(){String[] heads = new String[]{"编号","姓名","年龄","地址","状态","照片"};List<Employee> employees = new ArrayList<>();Employee employee1 = new Employee(1,"张三",23,"郑州","合法");Employee employee2 = new Employee(2,"李四",25,"合肥","合法");Employee employee3 = new Employee(3,"王五",26,"青岛","合法");Employee employee4 = new Employee(4,"王二麻子",27,"上海","合法");Employee employee5 = new Employee(5,"赵子龙",28,"北京","合法");Employee employee6 = new Employee(5,"刘能",28,"东北","合法");employees.add(employee1);employees.add(employee2);employees.add(employee3);employees.add(employee4);employees.add(employee5);employees.add(employee6);List<List<String>>  lists = new ArrayList<>();employees.forEach(employee -> {List<String> list = new ArrayList<>();list.add(String.valueOf(employee.getId()));list.add(employee.getName());list.add(String.valueOf(employee.getAge()));list.add(employee.getAddress());list.add(employee.getStatus());lists.add(list);});FileOutputStream fileOut = null;BufferedImage bufferImg = null;//先把读进来的图片放到一个ByteArrayOutputStream中,以便产生ByteArraytry {HSSFWorkbook wb = new HSSFWorkbook();HSSFSheet sheet = wb.createSheet("test picture");//填充表头数据HSSFRow row = sheet.createRow(0);for (int i = 0; i < heads.length; i++) {HSSFCell cell = row.createCell(i);cell.setCellValue(heads[i]);}//画图的顶级管理器,一个sheet只能获取一个(一定要注意这点)HSSFPatriarch patriarch = sheet.createDrawingPatriarch();//填充实际数据for (int i = 0; i < lists.size(); i++) {//因为第一行表头数据已经填充过,从第二行开始填充HSSFRow row2 = sheet.createRow(i + 1);List<String> stringList = lists.get(i);for (int j = 0; j < stringList.size() ; j++) {HSSFCell cell = row2.createCell(j);cell.setCellValue(stringList.get(j));}//设置图片列宽度sheet.setColumnWidth(5,30 * 256);ByteArrayOutputStream byteArrayOut = new ByteArrayOutputStream();bufferImg = ImageIO.read(new File("C:\\Users\\LiuBuJun\\Desktop\\timg .jpg"));ImageIO.write(bufferImg, "jpg", byteArrayOut);//原始宽度int width = bufferImg.getWidth();//原始高度int height = bufferImg.getHeight();//计算该列对应高度height = (int) Math.round((height * (30 * 13) * 1.0 / width));row2.setHeight((short) (height / 5 * 20));HSSFClientAnchor anchor = new HSSFClientAnchor(0, 0, 0, 0,(short) 5, (i+1),(short) 6, (i+2));//插入图片patriarch.createPicture(anchor, wb.addPicture(byteArrayOut.toByteArray(), HSSFWorkbook.PICTURE_TYPE_JPEG));}fileOut = new FileOutputStream("D:/测试Excel.xls");// 写入excel文件wb.write(fileOut);System.out.println("----Excle文件已生成------");} catch (Exception e) {e.printStackTrace();}finally{if(fileOut != null){try {fileOut.close();} catch (Exception e) {e.printStackTrace();}}}}

导出结果:

2.1 导出要点

要点1:

//设置图片列宽度
sheet.setColumnWidth(5,30 * 256);
ByteArrayOutputStream byteArrayOut = new ByteArrayOutputStream();
bufferImg = ImageIO.read(new File("C:\\Users\\LiuBuJun\\Desktop\\timg .jpg"));
ImageIO.write(bufferImg, "jpg", byteArrayOut);
//原始宽度
int width = bufferImg.getWidth();
//原始高度
int height = bufferImg.getHeight();
//计算该列对应高度
height = (int) Math.round((height * (30 * 13) * 1.0 / width));
row2.setHeight((short) (height / 5 * 20));

首先定义列的宽度,然后创建ByteArrayOutputStream,读取照片,并且根据照片的原本高度和宽度,计算导出到excel中的高度和宽度。

要点2:

/**
 * 该构造函数有8个参数
 * 前四个参数是控制图片在单元格的位置,分别是图片距离单元格left,top,right,bottom的像素距离
 * 后四个参数,前两个个表示图片左上角所在的cellNum1和 rowNum1,后两个参数对应的表示图片右下角所在的cellNum2和 rowNum2,其实cellNum2-cellNum1就是图片的宽度所占单元格,rowNum2-rowNum1就是图片高度所占单元格
 * excel中的cellNum和rowNum的index都是从0开始的
 */
HSSFClientAnchor anchor = new HSSFClientAnchor(0, 0, 0, 0,(short) 5, (i+1),(short) 6, (i+2));

3 SXSSFWorkbook

以上只是部分内容,为了维护方便,本文已迁移到新地址:excel导出图片—HSSFWorkbook–SXSSFWorkbook – 编程屋

相关文章:

  • <Rust>iced库(0.13.1)学习之部件(三十):button部件的使用
  • 为什么vue加载select大量数据会使页面造成卡顿
  • upsample nearest 临近上采样实现方式
  • taobao.item_get_appAPI接口原app数据测试指南
  • unity安装报错问题记录
  • 确保从IP池提取的IP是可用的对于数据抓取或其他网络活动至关重要。以下是一些确保IP可用性的有效方法:
  • 点评项目-3-登录成功后加载登录页面
  • Qt 每日面试题 -6
  • LVS+keepalived整合负载均衡配置
  • 物理学基础精解【41】
  • MySql中索引失效的情况及原因
  • CSS开发全攻略
  • ubuntu2204操作系统使用可执行文件方式安装docker-compose记录
  • Qt网络编程——QUdpSocket
  • [大语言模型-论文精读] MoRAG - 基于多部分融合的检索增强型人体动作生成
  • CentOS7简单部署NFS
  • java概述
  • java小心机(3)| 浅析finalize()
  • leetcode讲解--894. All Possible Full Binary Trees
  • nodejs调试方法
  • open-falcon 开发笔记(一):从零开始搭建虚拟服务器和监测环境
  • PHP 程序员也能做的 Java 开发 30分钟使用 netty 轻松打造一个高性能 websocket 服务...
  • python3 使用 asyncio 代替线程
  • python大佬养成计划----difflib模块
  • Python连接Oracle
  • React系列之 Redux 架构模式
  • supervisor 永不挂掉的进程 安装以及使用
  • 回顾 Swift 多平台移植进度 #2
  • 前言-如何学习区块链
  • 移动互联网+智能运营体系搭建=你家有金矿啊!
  • 曜石科技宣布获得千万级天使轮投资,全方面布局电竞产业链 ...
  • ​​​​​​​sokit v1.3抓手机应用socket数据包: Socket是传输控制层协议,WebSocket是应用层协议。
  • #大学#套接字
  • (aiohttp-asyncio-FFmpeg-Docker-SRS)实现异步摄像头转码服务器
  • (c语言+数据结构链表)项目:贪吃蛇
  • (SpringBoot)第七章:SpringBoot日志文件
  • (编译到47%失败)to be deleted
  • (多级缓存)多级缓存
  • (经验分享)作为一名普通本科计算机专业学生,我大学四年到底走了多少弯路
  • (十八)Flink CEP 详解
  • (四) 虚拟摄像头vivi体验
  • (原創) 如何將struct塞進vector? (C/C++) (STL)
  • (转)母版页和相对路径
  • (转)如何上传第三方jar包至Maven私服让maven项目可以使用第三方jar包
  • (转)微软牛津计划介绍——屌爆了的自然数据处理解决方案(人脸/语音识别,计算机视觉与语言理解)...
  • (转载)Linux 多线程条件变量同步
  • ***原理与防范
  • .mkp勒索病毒解密方法|勒索病毒解决|勒索病毒恢复|数据库修复
  • .NET Core SkiaSharp 替代 System.Drawing.Common 的一些用法
  • .NET Core 实现 Redis 批量查询指定格式的Key
  • .NET 将混合了多个不同平台(Windows Mac Linux)的文件 目录的路径格式化成同一个平台下的路径
  • .net6 当连接用户的shell断掉后,dotnet会自动关闭,达不到长期运行的效果。.NET 进程守护
  • .so文件(linux系统)
  • /dev下添加设备节点的方法步骤(通过device_create)
  • @Autowired @Resource @Qualifier的区别