不調(diào)用方法實現(xiàn)hutool導(dǎo)出excel圖片示例詳解
前言
最近在做excel導(dǎo)出文件,然后有一列是圖片展示,然后我們圖片搞了防盜鏈,如果直接點開鏈接,就是一個默認(rèn)圖片(無法展示),我就想著把圖片嵌入excel中展示,由于我框架用的是hutool去導(dǎo)出,我點開里面各種類,結(jié)果都沒有img的輸入excel的方法,氣死我了
騷操作
其實我也是一個cv工程師,百度找找有沒有大佬已經(jīng)實現(xiàn)這功能,然后就找到了,不是hutool里面的方法,是poi包下
輸出excel數(shù)據(jù)代碼
//寫入數(shù)據(jù) writer.write(xx, true);
導(dǎo)出類
xx 是List list,我們看下bo類,我們定義一個不存在的字段,方便塞入圖片列
@AllArgsConstructor
@NoArgsConstructor
@Builder
@Data
public class BO {
private String pic;
private String url;
}
這個類里頭有個url鏈接字段,pic是圖片展示的列,url我們是不展示的,所以需要加上下面這段代碼,就是如果這個字段跟excel列不匹配(不展示)的時候,就不展示出來,不然會展示列名為url
writer.setOnlyAlias(true);
輸出圖片
好家伙,在輸出數(shù)據(jù)之后,還要特殊處理excel
for (int i = 0; CollectionUtil.isNotEmpty(xx) && i < xx.size(); i++) {
//讀取圖片,這里自行讀取流,代碼做了模糊
byte[] pictureData = null;
//寫入圖片
Sheet sheet = writer.getSheet();
Drawing<?> drawingPatriarch = sheet.createDrawingPatriarch();
//設(shè)置圖片單元格位置 第5列展示圖片,i是行數(shù)
ClientAnchor anchor = drawingPatriarch.createAnchor(0, 0, 0, 0, 4 , i + 1, 4 + 1, i + 2);
//隨單元格改變位置和大小
anchor.setAnchorType(ClientAnchor.AnchorType.MOVE_AND_RESIZE);
//添加圖片
int pictureIndex = sheet.getWorkbook().addPicture(pictureData, HSSFWorkbook.PICTURE_TYPE_JPEG);
drawingPatriarch.createPicture(anchor, pictureIndex);
}
展示結(jié)果

吐槽
我覺得這個應(yīng)該封裝到hutool ExcelWriter方法里頭,這樣才能提高工具類的功能,我相信大部分公司都在用hutool,畢竟經(jīng)過社區(qū)以及時間的大量考驗,框架應(yīng)該更加完善才能滿足開發(fā)者的需求。
好吧,這就去提個issue,哈哈~
以上就是不調(diào)用方法實現(xiàn)hutool導(dǎo)出excel圖片示例詳解的詳細(xì)內(nèi)容,更多關(guān)于hutool導(dǎo)出excel圖片的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
使用Spring Boot創(chuàng)建Web應(yīng)用程序的示例代碼
本篇文章主要介紹了使用Spring Boot創(chuàng)建Web應(yīng)用程序的示例代碼,我們將使用Spring Boot構(gòu)建一個簡單的Web應(yīng)用程序,并為其添加一些有用的服務(wù),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-05-05
Mybatis插入Oracle數(shù)據(jù)庫日期型數(shù)據(jù)過程解析
這篇文章主要介紹了Mybatis插入Oracle數(shù)據(jù)庫日期型數(shù)據(jù)過程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-09-09
SpringBoot基于Disruptor實現(xiàn)高效的消息隊列?
Disruptor是一個開源的Java框架,它被設(shè)計用于在生產(chǎn)者-消費者問題上獲得盡量高的吞吐量和盡量低的延遲,本文主要介紹了SpringBoot基于Disruptor實現(xiàn)高效的消息隊列?,具有一定的參考價值,感興趣的可以了解一下2024-02-02
IDEA Maven Mybatis generator 自動生成代碼(實例講解)
下面小編就為大家分享一篇IDEA Maven Mybatis generator 自動生成代碼的實例講解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2017-12-12

