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

java?excel轉(zhuǎn)圖片常用的幾種方法對比及建議

 更新時間:2025年09月11日 09:38:34   作者:甄超鋒  
在Java開發(fā)中,借助報表插件能夠輕松實現(xiàn)將工作表、任意指定區(qū)域以及各種形狀類型轉(zhuǎn)換為圖片,這篇文章主要介紹了java?excel轉(zhuǎn)圖片常用的幾種方法對比及建議,文中通過代碼介紹的非常詳細,需要的朋友可以參考下

前言

在 Java 中實現(xiàn) Excel 轉(zhuǎn)圖片,常用的方法主要分為兩類:使用商業(yè)庫(簡單高效但可能收費)和使用開源庫組合(免費但實現(xiàn)復(fù)雜)。以下是幾種常用方案及實現(xiàn)思路:

一、使用商業(yè)庫(推薦用于復(fù)雜場景)

商業(yè)庫通常封裝了完整的 Excel 渲染邏輯,支持復(fù)雜表格、公式、圖表等轉(zhuǎn)換,使用簡單。

1. Aspose.Cells(功能最全面)

Aspose.Cells 是處理 Excel 的專業(yè)庫,支持將工作表、單元格區(qū)域或圖表直接轉(zhuǎn)換為圖片,支持多種格式(PNG/JPG/BMP 等)。

特點

  • 支持復(fù)雜表格、公式、圖表、樣式渲染
  • 無需安裝 Office,純 Java 實現(xiàn)
  • 商業(yè)付費(免費版有水?。?/li>

示例代碼

import com.aspose.cells.*;
import java.io.File;

public class AsposeExcelToImage {
    public static void main(String[] args) throws Exception {
        // 加載Excel文件
        Workbook workbook = new Workbook("input.xlsx");
        
        // 獲取第一個工作表
        Worksheet worksheet = workbook.getWorksheets().get(0);
        
        // 配置圖片選項(格式、分辨率等)
        ImageOrPrintOptions options = new ImageOrPrintOptions();
        options.setImageType(ImageType.PNG); // 輸出PNG格式
        options.setHorizontalResolution(300); // 分辨率
        options.setVerticalResolution(300);
        
        // 渲染整個工作表為圖片
        SheetRender render = new SheetRender(worksheet, options);
        render.toImage(0, "output_aspose.png"); // 保存圖片
        
        // 也可渲染指定單元格區(qū)域(例如A1到D10)
        CellArea area = new CellArea();
        area.startRow = 0;
        area.startColumn = 0;
        area.endRow = 9;
        area.endColumn = 3;
        worksheet.setPrintArea(area); // 設(shè)置打印區(qū)域即渲染區(qū)域
        render.toImage(0, "output_range.png");
    }
}

依賴(Maven):

<dependency>
    <groupId>com.aspose</groupId>
    <artifactId>aspose-cells</artifactId>
    <version>23.12</version>
</dependency>

2. Spire.XLS(性價比高)

Spire.XLS 是另一個商業(yè)庫,功能類似 Aspose.Cells,免費版有頁數(shù)限制(如最多轉(zhuǎn)換 5 頁)。

特點

  • 支持表格、圖表、形狀轉(zhuǎn)圖片
  • 免費版可滿足簡單需求

示例代碼

import com.spire.xls.*;

public class SpireExcelToImage {
    public static void main(String[] args) {
        // 加載Excel
        Workbook workbook = new Workbook();
        workbook.loadFromFile("input.xlsx");
        
        // 獲取第一個工作表
        Worksheet sheet = workbook.getWorksheets().get(0);
        
        // 保存為圖片(支持指定區(qū)域)
        sheet.saveToImage("output_spire.png");
        
        // 保存指定單元格區(qū)域(A1到C8)
        sheet.saveToImage(0, 0, 7, 2, "output_spire_range.png"); // 行、列起始索引及結(jié)束索引
    }
}

依賴(Maven):

<dependency>
    <groupId>e-iceblue</groupId>
    <artifactId>spire.xls</artifactId>
    <version>14.7.0</version>
</dependency>

二、開源方案(適合簡單場景,免費)

開源方案需要組合多個庫實現(xiàn),核心思路是:用 Excel 解析庫讀取內(nèi)容 + 用圖形庫繪制圖片。

1. Apache POI + BufferedImage(基礎(chǔ)實現(xiàn))

Apache POI 是處理 Excel 的主流開源庫,但本身不支持直接轉(zhuǎn)圖片,需要手動讀取單元格內(nèi)容、樣式(邊框、顏色等),再用 Java 的BufferedImage繪制。

特點

  • 完全免費,可定制化
  • 僅適合簡單表格(復(fù)雜樣式、公式、圖表難以實現(xiàn))
  • 需手動處理樣式渲染,開發(fā)成本高

核心步驟

  1. 用 Apache POI 讀取 Excel 內(nèi)容(單元格值、字體、顏色、邊框等)
  2. 計算表格寬高、單元格大小
  3. BufferedImageGraphics2D繪制單元格、文字、邊框
  4. 保存為圖片

示例代碼片段

import org.apache.poi.ss.usermodel.*;
import javax.imageio.ImageIO;
import java.awt.*;
import java.awt.image.BufferedImage;
import java.io.File;

public class PoiExcelToImage {
    public static void main(String[] args) throws Exception {
        Workbook workbook = WorkbookFactory.create(new File("input.xlsx"));
        Sheet sheet = workbook.getSheetAt(0);
        
        // 簡單計算圖片寬高(實際需根據(jù)單元格大小動態(tài)計算)
        int width = 800;
        int height = 600;
        BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);
        Graphics2D g = image.createGraphics();
        
        // 繪制背景
        g.setColor(Color.WHITE);
        g.fillRect(0, 0, width, height);
        
        // 繪制單元格(簡化示例,僅繪制文本)
        int rowY = 50;
        for (Row row : sheet) {
            int colX = 50;
            for (Cell cell : row) {
                String value = cell.getStringCellValue();
                // 繪制文本
                g.setColor(Color.BLACK);
                g.drawString(value, colX, rowY);
                colX += 100; // 單元格寬度
            }
            rowY += 30; // 行高
        }
        
        // 保存圖片
        ImageIO.write(image, "PNG", new File("output_poi.png"));
        g.dispose();
    }
}

依賴(Maven):

<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi</artifactId>
    <version>5.2.4</version>
</dependency>
<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi-ooxml</artifactId>
    <version>5.2.4</version>
</dependency>

2. Apache POI + JFreeChart(處理圖表)

如果需要轉(zhuǎn)換 Excel 中的圖表,可結(jié)合 JFreeChart(開源圖表庫):

  1. 用 POI 讀取圖表數(shù)據(jù)
  2. 用 JFreeChart 生成對應(yīng)圖表圖片
  3. 合并表格圖片和圖表圖片(如需)

三、方法對比與選擇建議

方法優(yōu)點缺點適用場景
Aspose.Cells功能全面,支持復(fù)雜表格 / 圖表,易用商業(yè)付費,免費版有水印生產(chǎn)環(huán)境、復(fù)雜 Excel 轉(zhuǎn)換
Spire.XLS性價比高,免費版可用免費版有頁數(shù)限制簡單需求、小文件轉(zhuǎn)換
Apache POI + 自定義免費開源,可深度定制開發(fā)復(fù)雜,不支持復(fù)雜樣式 / 公式簡單表格、低成本場景

總結(jié)

  • 追求效率和完整性:優(yōu)先選擇 Aspose.Cells 或 Spire.XLS
  • 免費且簡單場景:用 Apache POI 手動繪制(僅限簡單表格)
  • 避免重復(fù)造輪子:商業(yè)庫是大多數(shù)企業(yè)的選擇(可評估成本)

到此這篇關(guān)于java excel轉(zhuǎn)圖片常用的幾種方法對比及建議的文章就介紹到這了,更多相關(guān)java excel轉(zhuǎn)圖片方法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 詳解Java中HashSet和TreeSet的區(qū)別

    詳解Java中HashSet和TreeSet的區(qū)別

    這篇文章主要介紹了詳解Java中HashSet和TreeSet的區(qū)別的相關(guān)資料,需要的朋友可以參考下
    2017-06-06
  • SpringValidation自定義注解及分組校驗功能詳解

    SpringValidation自定義注解及分組校驗功能詳解

    這篇文章主要介紹了SpringValidation自定義注解及分組校驗功能,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2024-01-01
  • mybatis的好幫手之MybatisCodeHelperPro詳解

    mybatis的好幫手之MybatisCodeHelperPro詳解

    這篇文章主要介紹了mybatis的好幫手之MybatisCodeHelperPro詳解,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-09-09
  • Spring Data JPA使用JPQL與原生SQL進行查詢的操作

    Spring Data JPA使用JPQL與原生SQL進行查詢的操作

    這篇文章主要介紹了Spring Data JPA使用JPQL與原生SQL進行查詢的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • java  Vector和ArrayList的分析及比較

    java Vector和ArrayList的分析及比較

    這篇文章主要介紹了java Vector和ArrayList的分析及比較的相關(guān)資料,Vector是多線程安全的,而ArrayList不是,本文主要做對比對這兩個方法,需要的朋友可以參考下
    2016-11-11
  • Spring Security基于json登錄實現(xiàn)過程詳解

    Spring Security基于json登錄實現(xiàn)過程詳解

    這篇文章主要介紹了Spring Security基于json登錄實現(xiàn)過程詳解,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-08-08
  • activemq整合springboot使用方法(個人微信小程序用)

    activemq整合springboot使用方法(個人微信小程序用)

    這篇文章主要介紹了activemq整合springboot使用(個人微信小程序用),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • Spring的自定義擴展標簽NamespaceHandler解析

    Spring的自定義擴展標簽NamespaceHandler解析

    這篇文章主要介紹了Spring的自定義擴展標簽NamespaceHandler解析,在很多情況下,我們需要為系統(tǒng)提供可配置化支持,簡單的做法可以直接基于Spring的標準Bean來配置,Spring提供了可擴展Schema的支持,這是一個不錯的折中方案,需要的朋友可以參考下
    2023-12-12
  • 基于springboot創(chuàng)建mybatis的完整步驟

    基于springboot創(chuàng)建mybatis的完整步驟

    MyBatis是一款優(yōu)秀的數(shù)據(jù)庫持久層框架,相比Hibernate我更喜歡使用MyBatis,看的到SQL還是讓人更安心點,這篇文章主要給大家介紹了關(guān)于基于springboot創(chuàng)建mybatis的完整步驟,需要的朋友可以參考下
    2024-03-03
  • Java實現(xiàn)stream的三個常用方式(toMap,groupingBy,findFirst)

    Java實現(xiàn)stream的三個常用方式(toMap,groupingBy,findFirst)

    本文主要介紹了Java實現(xiàn)stream的三個常用方式,主要包括toMap,groupingBy,findFirst,具有一定的參考價值,感興趣的可以了解一下
    2023-10-10

最新評論