欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

不調(diào)用方法實(shí)現(xiàn)hutool導(dǎo)出excel圖片示例詳解

 更新時(shí)間:2022年08月16日 10:36:35   作者:大雞腿同學(xué)  
這篇文章主要為大家介紹了不調(diào)用方法實(shí)現(xiàn)hutool導(dǎo)出excel圖片示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

前言

最近在做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)文章

  • log4j2的異步使用及添加自定義參數(shù)方式

    log4j2的異步使用及添加自定義參數(shù)方式

    這篇文章主要介紹了log4j2的異步使用及添加自定義參數(shù)方式,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-12-12
  • 線程池中execute與submit的區(qū)別說明

    線程池中execute與submit的區(qū)別說明

    這篇文章主要介紹了線程池execute與submit的區(qū)別說明,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • 使用Spring Boot創(chuàng)建Web應(yīng)用程序的示例代碼

    使用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-05
  • Mybatis插入Oracle數(shù)據(jù)庫日期型數(shù)據(jù)過程解析

    Mybatis插入Oracle數(shù)據(jù)庫日期型數(shù)據(jù)過程解析

    這篇文章主要介紹了Mybatis插入Oracle數(shù)據(jù)庫日期型數(shù)據(jù)過程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-09-09
  • Java枚舉的使用方法詳解

    Java枚舉的使用方法詳解

    這篇文章主要介紹了 Java枚舉的使用方法詳解的相關(guān)資料,希望通過本文大家能掌握枚舉的使用方法,需要的朋友可以參考下
    2017-09-09
  • Java利用JavaCPP調(diào)用算法示例

    Java利用JavaCPP調(diào)用算法示例

    本文主要介紹了Java利用JavaCPP調(diào)用算法示例,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • SpringBoot基于Disruptor實(shí)現(xiàn)高效的消息隊(duì)列?

    SpringBoot基于Disruptor實(shí)現(xiàn)高效的消息隊(duì)列?

    Disruptor是一個(gè)開源的Java框架,它被設(shè)計(jì)用于在生產(chǎn)者-消費(fèi)者問題上獲得盡量高的吞吐量和盡量低的延遲,本文主要介紹了SpringBoot基于Disruptor實(shí)現(xiàn)高效的消息隊(duì)列?,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-02-02
  • SpringBoot之QueryDsl嵌套子查詢問題

    SpringBoot之QueryDsl嵌套子查詢問題

    這篇文章主要介紹了SpringBoot之QueryDsl嵌套子查詢問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • IDEA Maven Mybatis generator 自動(dòng)生成代碼(實(shí)例講解)

    IDEA Maven Mybatis generator 自動(dòng)生成代碼(實(shí)例講解)

    下面小編就為大家分享一篇IDEA Maven Mybatis generator 自動(dòng)生成代碼的實(shí)例講解,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2017-12-12
  • java如何獲取本機(jī)IP地址

    java如何獲取本機(jī)IP地址

    這篇文章主要為大家詳細(xì)介紹了java如何獲取本機(jī)IP地址,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-03-03

最新評論