From cbdba9a0cda2efa09778f58c23ba0fa8b760eede Mon Sep 17 00:00:00 2001 From: zhuangjiaju Date: Mon, 19 Aug 2019 19:10:54 +0800 Subject: [PATCH] =?UTF-8?q?=E4=BC=98=E5=8C=96=E8=AF=BB=E5=86=99=E9=80=BB?= =?UTF-8?q?=E8=BE=91?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- img/readme/quickstart/write/imageWrite.png | Bin 0 -> 9060 bytes quickstart.md | 53 ++++++++++++++++++ .../easyexcel/test/demo/write/ImageData.java | 30 ++++++++++ .../easyexcel/test/demo/write/WriteTest.java | 35 +++++++++++- 4 files changed, 116 insertions(+), 2 deletions(-) create mode 100644 img/readme/quickstart/write/imageWrite.png create mode 100644 src/test/java/com/alibaba/easyexcel/test/demo/write/ImageData.java diff --git a/img/readme/quickstart/write/imageWrite.png b/img/readme/quickstart/write/imageWrite.png new file mode 100644 index 0000000000000000000000000000000000000000..c6a0c67a91dc5a7022a8cd04ff727258f34794d0 GIT binary patch literal 9060 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 literal 0 HcmV?d00001 diff --git a/quickstart.md b/quickstart.md index 42b0ea2..28b8bf3 100644 --- a/quickstart.md +++ b/quickstart.md @@ -16,6 +16,7 @@ DEMO代码地址:[https://github.com/alibaba/easyexcel/blob/master/src/test/ja * [复杂头写入](#complexHeadWrite) * [重复多次写入](#repeatedWrite) * [日期、数字或者自定义格式转换](#converterWrite) +* [图片导出](#imageWrite) * [根据模板写入](#templateWrite) * [列宽、行高](#widthAndHeightWrite) * [自定义样式](#styleWrite) @@ -537,6 +538,58 @@ public class ConverterData { } ``` +### 图片导出 +##### excel示例 +![img](img/readme/quickstart/write/imageWrite.png) +##### 对象 +```java +@Data +@ContentRowHeight(100) +@ColumnWidth(100 / 8) +public class ImageData { + private File file; + private InputStream inputStream; + /** + * 如果string类型 必须指定转换器,string默认转换成string + */ + @ExcelProperty(converter = StringImageConverter.class) + private String string; + private byte[] byteArray; +} +``` +##### 代码 +```java + /** + * 图片导出 + *
  • 1. 创建excel对应的实体对象 参照{@link ImageData} + *
  • 2. 直接写即可 + */ + @Test + public void imageWrite() throws Exception { + String fileName = TestFileUtil.getPath() + "imageWrite" + System.currentTimeMillis() + ".xlsx"; + // 如果使用流 记得关闭 + InputStream inputStream = null; + try { + List list = new ArrayList(); + ImageData imageData = new ImageData(); + list.add(imageData); + String imagePath = TestFileUtil.getPath() + "converter" + File.separator + "img.jpg"; + // 放入四种类型的图片 实际使用只要选一种即可 + imageData.setByteArray(FileUtils.readFileToByteArray(new File(imagePath))); + imageData.setFile(new File(imagePath)); + imageData.setString(imagePath); + inputStream = FileUtils.openInputStream(new File(imagePath)); + imageData.setInputStream(inputStream); + EasyExcel.write(fileName, ImageData.class).sheet().doWrite(list); + } finally { + if (inputStream != null) { + inputStream.close(); + } + } + } +``` + + ### 根据模板写入 ##### 模板excel示例 参照:[模板excel示例](#simpleReadExcel) diff --git a/src/test/java/com/alibaba/easyexcel/test/demo/write/ImageData.java b/src/test/java/com/alibaba/easyexcel/test/demo/write/ImageData.java new file mode 100644 index 0000000..951026c --- /dev/null +++ b/src/test/java/com/alibaba/easyexcel/test/demo/write/ImageData.java @@ -0,0 +1,30 @@ +package com.alibaba.easyexcel.test.demo.write; + +import java.io.File; +import java.io.InputStream; + +import com.alibaba.excel.annotation.ExcelProperty; +import com.alibaba.excel.annotation.write.style.ColumnWidth; +import com.alibaba.excel.annotation.write.style.ContentRowHeight; +import com.alibaba.excel.converters.string.StringImageConverter; + +import lombok.Data; + +/** + * 图片导出类 + * + * @author Jiaju Zhuang + */ +@Data +@ContentRowHeight(100) +@ColumnWidth(100 / 8) +public class ImageData { + private File file; + private InputStream inputStream; + /** + * 如果string类型 必须指定转换器,string默认转换成string + */ + @ExcelProperty(converter = StringImageConverter.class) + private String string; + private byte[] byteArray; +} diff --git a/src/test/java/com/alibaba/easyexcel/test/demo/write/WriteTest.java b/src/test/java/com/alibaba/easyexcel/test/demo/write/WriteTest.java index baffae6..9bd9467 100644 --- a/src/test/java/com/alibaba/easyexcel/test/demo/write/WriteTest.java +++ b/src/test/java/com/alibaba/easyexcel/test/demo/write/WriteTest.java @@ -1,6 +1,7 @@ package com.alibaba.easyexcel.test.demo.write; import java.io.File; +import java.io.InputStream; import java.util.ArrayList; import java.util.Date; import java.util.List; @@ -20,6 +21,7 @@ import com.alibaba.excel.annotation.format.NumberFormat; import com.alibaba.excel.annotation.write.style.ColumnWidth; import com.alibaba.excel.annotation.write.style.ContentRowHeight; import com.alibaba.excel.annotation.write.style.HeadRowHeight; +import com.alibaba.excel.util.FileUtils; import com.alibaba.excel.write.merge.LoopMergeStrategy; import com.alibaba.excel.write.metadata.WriteSheet; import com.alibaba.excel.write.metadata.WriteTable; @@ -117,6 +119,35 @@ public class WriteTest { EasyExcel.write(fileName, ConverterData.class).sheet("模板").doWrite(data()); } + /** + * 图片导出 + *
  • 1. 创建excel对应的实体对象 参照{@link ImageData} + *
  • 2. 直接写即可 + */ + @Test + public void imageWrite() throws Exception { + String fileName = TestFileUtil.getPath() + "imageWrite" + System.currentTimeMillis() + ".xlsx"; + // 如果使用流 记得关闭 + InputStream inputStream = null; + try { + List list = new ArrayList(); + ImageData imageData = new ImageData(); + list.add(imageData); + String imagePath = TestFileUtil.getPath() + "converter" + File.separator + "img.jpg"; + // 放入四种类型的图片 实际使用只要选一种即可 + imageData.setByteArray(FileUtils.readFileToByteArray(new File(imagePath))); + imageData.setFile(new File(imagePath)); + imageData.setString(imagePath); + inputStream = FileUtils.openInputStream(new File(imagePath)); + imageData.setInputStream(inputStream); + EasyExcel.write(fileName, ImageData.class).sheet().doWrite(list); + } finally { + if (inputStream != null) { + inputStream.close(); + } + } + } + /** * 根据模板写入 *
  • 1. 创建excel对应的实体对象 参照{@link IndexData} @@ -192,8 +223,7 @@ public class WriteTest { // 每隔2行会合并 把eachColumn 设置成 3 也就是我们数据的长度,所以就第一列会合并。当然其他合并策略也可以自己写 LoopMergeStrategy loopMergeStrategy = new LoopMergeStrategy(2, 0); // 这里 需要指定写用哪个class去读,然后写到第一个sheet,名字为模板 然后文件流会自动关闭 - EasyExcel.write(fileName, DemoData.class).registerWriteHandler(loopMergeStrategy).sheet("模板") - .doWrite(data()); + EasyExcel.write(fileName, DemoData.class).registerWriteHandler(loopMergeStrategy).sheet("模板").doWrite(data()); } /** @@ -297,4 +327,5 @@ public class WriteTest { } return list; } + }