不調(diào)用方法實(shí)現(xiàn)hutool導(dǎo)出excel圖片示例詳解
前言
最近在做excel導(dǎo)出文件,然后有一列是圖片展示,然后我們圖片搞了防盜鏈,如果直接點(diǎn)開鏈接,就是一個(gè)默認(rèn)圖片(無法展示),我就想著把圖片嵌入excel中展示,由于我框架用的是hutool去導(dǎo)出,我點(diǎn)開里面各種類,結(jié)果都沒有img的輸入excel的方法,氣死我了
騷操作
其實(shí)我也是一個(gè)cv工程師,百度找找有沒有大佬已經(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í)候,就不展示出來,不然會(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é)果
吐槽
我覺得這個(gè)應(yīng)該封裝到hutool ExcelWriter方法里頭,這樣才能提高工具類的功能,我相信大部分公司都在用hutool,畢竟經(jīng)過社區(qū)以及時(shí)間的大量考驗(yàn),框架應(yīng)該更加完善才能滿足開發(fā)者的需求。
好吧,這就去提個(gè)issue,哈哈~
以上就是不調(diào)用方法實(shí)現(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)建一個(gè)簡單的Web應(yīng)用程序,并為其添加一些有用的服務(wù),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-05-05Mybatis插入Oracle數(shù)據(jù)庫日期型數(shù)據(jù)過程解析
這篇文章主要介紹了Mybatis插入Oracle數(shù)據(jù)庫日期型數(shù)據(jù)過程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-09-09SpringBoot基于Disruptor實(shí)現(xiàn)高效的消息隊(duì)列?
Disruptor是一個(gè)開源的Java框架,它被設(shè)計(jì)用于在生產(chǎn)者-消費(fèi)者問題上獲得盡量高的吞吐量和盡量低的延遲,本文主要介紹了SpringBoot基于Disruptor實(shí)現(xiàn)高效的消息隊(duì)列?,具有一定的參考價(jià)值,感興趣的可以了解一下2024-02-02IDEA Maven Mybatis generator 自動(dòng)生成代碼(實(shí)例講解)
下面小編就為大家分享一篇IDEA Maven Mybatis generator 自動(dòng)生成代碼的實(shí)例講解,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2017-12-12