不調(diào)用方法實(shí)現(xiàn)hutool導(dǎo)出excel圖片示例詳解
前言
最近在做excel導(dǎo)出文件,然后有一列是圖片展示,然后我們圖片搞了防盜鏈,如果直接點(diǎn)開(kāi)鏈接,就是一個(gè)默認(rèn)圖片(無(wú)法展示),我就想著把圖片嵌入excel中展示,由于我框架用的是hutool去導(dǎo)出,我點(diǎn)開(kāi)里面各種類,結(jié)果都沒(méi)有img的輸入excel的方法,氣死我了
騷操作
其實(shí)我也是一個(gè)cv工程師,百度找找有沒(méi)有大佬已經(jīng)實(shí)現(xiàn)這功能,然后就找到了,不是hutool里面的方法,是poi包下
輸出excel數(shù)據(jù)代碼
//寫入數(shù)據(jù) writer.write(xx, true);
導(dǎo)出類
xx 是List list,我們看下bo類,我們定義一個(gè)不存在的字段,方便塞入圖片列
@AllArgsConstructor
@NoArgsConstructor
@Builder
@Data
public class BO {
private String pic;
private String url;
}
這個(gè)類里頭有個(gè)url鏈接字段,pic是圖片展示的列,url我們是不展示的,所以需要加上下面這段代碼,就是如果這個(gè)字段跟excel列不匹配(不展示)的時(shí)候,就不展示出來(lái),不然會(huì)展示列名為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é)果

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

