java在excel里插入文字数据和图片(JXL方式)

2024-06-17 00:32

本文主要是介绍java在excel里插入文字数据和图片(JXL方式),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

如题所示,这里讲述下如何通过JXL包在excel里插入文字数据以及图片。

这里先展示下后续文章里要提到的1.xls(模板文件)和2.xls(导出文件)

        1.xls:


2.xls(空白的excel):


要导入的图片(320*240):

附上代码:

<span style="font-size:14px;">package com.test.http;import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;import jxl.Workbook;
import jxl.write.Label;
import jxl.write.WritableImage;
import jxl.write.WritableSheet;
import jxl.write.WritableWorkbook;
import jxl.write.WriteException;import org.junit.Test;public class ExcelTest {@Testpublic void portExcel() {OutputStream os = null;WritableWorkbook wbook = null;InputStream is = null;try {//获取输入流is = new FileInputStream("C:/Users/test/Desktop/1.xls");//获取输出流os = new FileOutputStream("C:/Users/test/Desktop/2.xls");//创建WritableWorkbook对象wbook = Workbook.createWorkbook(os, Workbook.getWorkbook(is));//获取sheet对象WritableSheet sheet = wbook.getSheet(0);//初始化行int row = 0;//初始化列int col = 0;col = 0;row++;//图片文件/*** <span style="color:#ff0000;">注意:jxl里插入图片,图片必须为png格式</span>* (我这里图片比例为4:3, 图片那列,列宽是在1.xls里设置好的,行高在代码里设置)*/File imgFile = new File("C:/Users/test/Desktop/456.png");sheet.addCell(new Label(col++, row, "123456789"));sheet.addCell(new Label(col++, row, "张三"));sheet.addCell(new Label(col++, row, "男"));sheet.addCell(new Label(col++, row, "37053318580536451X"));sheet.addCell(new Label(col++, row, "李四"));sheet.addCell(new Label(col++, row, "鲁A99999"));sheet.addCell(new Label(col++, row, "18888888888"));sheet.addCell(new Label(col++, row, "2016-04-12 14:09:09"));sheet.addCell(new Label(col++, row, "2016-05-15 13:11:45"));sheet.addCell(new Label(col++, row, "来此厂参观"));/**WritableImage(double x,double y,double width,double height,java.io.File image)* x - the column number at which to position the image 图片左上角位置为多少列* y - the row number at which to position the image 图片左上角位置为多少行* width - the number of columns cells which the image spans 图片宽度在excel里占据多少列* height - the number of rows which the image spans 图片宽度在excel里占据多少行* image - the source image file 图片文件地址* */WritableImage image = new WritableImage(col++, row, 1, 1, imgFile);sheet.setRowView(row, 1700, false); //设置行高// 把图片插入到sheetsheet.addImage(image);//          如果需要插入多张图片,则按下面的方式继续添加
//          WritableImage image2 = new WritableImage(10, 2, 1, 1, imgFile);
//          sheet.addImage(image);//设置行高wbook.write();} catch (Exception e) {e.printStackTrace();} finally {try {if (is != null) {is.close();}if (wbook != null) {wbook.close();}if (os != null) {os.flush();os.close();}} catch (WriteException e) {e.printStackTrace();} catch (IOException e) {e.printStackTrace();}}}}</span>
最后附上执行以上代码后的2.xls(因图片上传到博客里有点压缩,实际效果图片在单元格里以4:3的比例显示):



这篇关于java在excel里插入文字数据和图片(JXL方式)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1067985

相关文章

SpringBoot使用Apache Tika检测敏感信息

《SpringBoot使用ApacheTika检测敏感信息》ApacheTika是一个功能强大的内容分析工具,它能够从多种文件格式中提取文本、元数据以及其他结构化信息,下面我们来看看如何使用Ap... 目录Tika 主要特性1. 多格式支持2. 自动文件类型检测3. 文本和元数据提取4. 支持 OCR(光学

Java内存泄漏问题的排查、优化与最佳实践

《Java内存泄漏问题的排查、优化与最佳实践》在Java开发中,内存泄漏是一个常见且令人头疼的问题,内存泄漏指的是程序在运行过程中,已经不再使用的对象没有被及时释放,从而导致内存占用不断增加,最终... 目录引言1. 什么是内存泄漏?常见的内存泄漏情况2. 如何排查 Java 中的内存泄漏?2.1 使用 J

JAVA系统中Spring Boot应用程序的配置文件application.yml使用详解

《JAVA系统中SpringBoot应用程序的配置文件application.yml使用详解》:本文主要介绍JAVA系统中SpringBoot应用程序的配置文件application.yml的... 目录文件路径文件内容解释1. Server 配置2. Spring 配置3. Logging 配置4. Ma

Python MySQL如何通过Binlog获取变更记录恢复数据

《PythonMySQL如何通过Binlog获取变更记录恢复数据》本文介绍了如何使用Python和pymysqlreplication库通过MySQL的二进制日志(Binlog)获取数据库的变更记录... 目录python mysql通过Binlog获取变更记录恢复数据1.安装pymysqlreplicat

Linux使用dd命令来复制和转换数据的操作方法

《Linux使用dd命令来复制和转换数据的操作方法》Linux中的dd命令是一个功能强大的数据复制和转换实用程序,它以较低级别运行,通常用于创建可启动的USB驱动器、克隆磁盘和生成随机数据等任务,本文... 目录简介功能和能力语法常用选项示例用法基础用法创建可启动www.chinasem.cn的 USB 驱动

Java 字符数组转字符串的常用方法

《Java字符数组转字符串的常用方法》文章总结了在Java中将字符数组转换为字符串的几种常用方法,包括使用String构造函数、String.valueOf()方法、StringBuilder以及A... 目录1. 使用String构造函数1.1 基本转换方法1.2 注意事项2. 使用String.valu

使用SQL语言查询多个Excel表格的操作方法

《使用SQL语言查询多个Excel表格的操作方法》本文介绍了如何使用SQL语言查询多个Excel表格,通过将所有Excel表格放入一个.xlsx文件中,并使用pandas和pandasql库进行读取和... 目录如何用SQL语言查询多个Excel表格如何使用sql查询excel内容1. 简介2. 实现思路3

python实现pdf转word和excel的示例代码

《python实现pdf转word和excel的示例代码》本文主要介绍了python实现pdf转word和excel的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录一、引言二、python编程1,PDF转Word2,PDF转Excel三、前端页面效果展示总结一

java脚本使用不同版本jdk的说明介绍

《java脚本使用不同版本jdk的说明介绍》本文介绍了在Java中执行JavaScript脚本的几种方式,包括使用ScriptEngine、Nashorn和GraalVM,ScriptEngine适用... 目录Java脚本使用不同版本jdk的说明1.使用ScriptEngine执行javascript2.

Mybatis官方生成器的使用方式

《Mybatis官方生成器的使用方式》本文详细介绍了MyBatisGenerator(MBG)的使用方法,通过实际代码示例展示了如何配置Maven插件来自动化生成MyBatis项目所需的实体类、Map... 目录1. MyBATis Generator 简介2. MyBatis Generator 的功能3