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

Java 將Excel轉(zhuǎn)為SVG的方法

 更新時(shí)間:2021年05月28日 14:43:32   作者:E-iceblue  
本文以Java示例展示如何將Excel文檔轉(zhuǎn)為SVG格式。通過本文中的方法,在將Excel轉(zhuǎn)為SVG時(shí),如果sheet工作表中手動(dòng)設(shè)置了分頁,則將每個(gè)分頁的內(nèi)容單獨(dú)保存為一個(gè)svg文件,如果sheet工作表中沒有設(shè)置分頁,則將Excel sheet表格中默認(rèn)的分頁范圍保存為svg。

1. 程序運(yùn)行環(huán)境如下:

編譯工具:IDEA

JDK版本:1.8.0

Excel測試文檔:.xlsx 2013

Excel工具jar包:free spire.xls.jar 3.9.1

2.關(guān)于如何導(dǎo)入jar包

方法1:手動(dòng)下載jar包。解壓,將文件路徑:D:\...\Spire.Xls-FE_3.9.1\lib\Spire.Xls.jar中的文件導(dǎo)入Java程序(即本文中使用的方法)。

方法2:Maven倉庫下載導(dǎo)入。先在maven程序中配置pom.xml文件,如下內(nèi)容:

<repositories>

        <repository>

            <id>com.e-iceblue</id>

            <url>http://repo.e-iceblue.cn/repository/maven-public/</url>

        </repository>

    </repositories>

<dependencies>

    <dependency>

        <groupId> e-iceblue </groupId>

        <artifactId>spire.xls.free</artifactId>

        <version>3.9.1</version>

    </dependency>

</dependencies>

完成配置后,點(diǎn)擊“Import”下載導(dǎo)入。

3. Java代碼

import com.spire.xls.*;

import java.io.FileOutputStream;
import java.util.List;
import java.util.Map;


public class ExcelToSVG {
    public static void main(String[] args) throws Exception{
        //加載Excel測試文檔
        Workbook workbook = new Workbook();
        workbook.loadFromFile("sample.xlsx");

        int count = 1;

        //獲取分頁信息
        List<Map<Integer, PageColRow>> pageInfoList = workbook.getSplitPageInfo();

        //遍歷工作表
        for (int i = 0; i < workbook.getWorksheets().getCount(); i++)
        {
            Worksheet sheet = workbook.getWorksheets().get(i);

            FileOutputStream stream;
            Map integerPageColRowMap = pageInfoList.get(i);//獲取每頁sheet的分頁信息
            for (Object object : integerPageColRowMap.values())
            {
                PageColRow colRow = (PageColRow) object;

                stream = new FileOutputStream( (count++) + "-ExcelToSVG.svg");//指定文件名輸出格式

                //保存為SVG
                sheet.toSVGStream(stream, colRow.StartRow, colRow.StartCol, colRow.EndRow, colRow.EndCol);
                stream.flush();
                stream.close();
            }
        }

    }
}

轉(zhuǎn)換結(jié)果可在IDEA項(xiàng)目文件夾下查看,如下圖:

另一種方法

同樣使用Free-Spire-XLS 

依賴引入同上

轉(zhuǎn)換工具類

import com.spire.xls.Worksheet;
import org.apache.poi.ss.usermodel.Workbook;
import sun.misc.BASE64Encoder;
 
import javax.imageio.ImageIO;
import javax.imageio.stream.ImageInputStream;
import javax.servlet.http.HttpServletResponse;
import java.awt.image.BufferedImage;
import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.InputStream;
 
 
/**
 * Excel轉(zhuǎn)換處理工具類:轉(zhuǎn)為圖片、svg文件等
 *
 * @author yangfeng
 * @date 2019-12-26
 */
public class ExcelTransformUtil {
 
    /**
     * workbook 轉(zhuǎn)為輸入流
     *
     * @param workbook
     * @return
     * @throws Exception
     */
    public static InputStream convert2Stream(Workbook workbook) throws Exception {
        ByteArrayOutputStream bos = new ByteArrayOutputStream();
        workbook.write(bos);
        byte[] barray = bos.toByteArray();
        return new ByteArrayInputStream(barray);
    }
 
    /**
     * excel 轉(zhuǎn)為圖片
     *
     * @param inputStream
     */
    public static void excel2Img(InputStream inputStream) {
        com.spire.xls.Workbook book;
        try {
            book = new com.spire.xls.Workbook();
            book.loadFromStream(inputStream);
            Worksheet sheet = book.getWorksheets().get(0);
            sheet.saveToImage("d://toImg.png");
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
 
    /**
     * excel 轉(zhuǎn)為SVG
     *
     * @param inputStream
     */
    public static void excel2SVG(InputStream inputStream, HttpServletResponse response) {
        com.spire.xls.Workbook book;
        try {
            book = new com.spire.xls.Workbook();
            book.loadFromStream(inputStream);
            Worksheet sheet = book.getWorksheets().get(0);
            sheet.toSVGStream(response.getOutputStream(), sheet.getFirstRow(), sheet.getFirstColumn(),
                    sheet.getLastRow(), sheet.getLastColumn());
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

生成svg服務(wù)

 public void generateSVG(ReportRequest request, HttpServletResponse response) throws Exception {
        ServiceResult<List<OperationReportVO>> result = getOperationReport(request);
        if (result != null && result.isSucceed() && !CollectionUtils.isEmpty(result.getData())) {
            //轉(zhuǎn)為map
            List<Map<String, Object>> list = MapBeanUtil.objectsToMaps(result.getData());
            Workbook workbook = ReportExportUtil.generateExcelReport("運(yùn)行情況統(tǒng)計(jì)表",
                    getDateAndWeek(request.getPlanDate()), list, OperationReportVO.class);
            ExcelTransformUtil.excel2SVG(ExcelTransformUtil.convert2Stream(workbook), response);
        }
    }

    此處的Workbook引自包:org.apache.poi.ss.usermodel.Workbook 。生成excel的workbook。然后將workbook轉(zhuǎn)為輸入流,com.spire.xls.Workbook讀取輸入流,轉(zhuǎn)成svg。

以上就是Java 將Excel轉(zhuǎn)為SVG的方法的詳細(xì)內(nèi)容,更多關(guān)于Java 將Excel轉(zhuǎn)為SVG的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 詳解Java中Collections.sort排序

    詳解Java中Collections.sort排序

    Comparator是個(gè)接口,可重寫compare()及equals()這兩個(gè)方法,接下來通過本文給大家介紹Java中Collections.sort排序,需要的的朋友參考下吧
    2017-04-04
  • Java使用Spring發(fā)送郵件的實(shí)現(xiàn)代碼

    Java使用Spring發(fā)送郵件的實(shí)現(xiàn)代碼

    本篇文章主要介紹了使用Spring發(fā)送郵件的實(shí)現(xiàn)代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-03-03
  • SpringCloud配置中心Config過程解析

    SpringCloud配置中心Config過程解析

    這篇文章主要介紹了SpringCloud配置中心Config過程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-03-03
  • Gradle jvm插件系列教程之Java?Library插件權(quán)威詳解

    Gradle jvm插件系列教程之Java?Library插件權(quán)威詳解

    這篇文章主要介紹了Java?Library插件權(quán)威詳解,本文通過示例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2024-01-01
  • Spring?boot詳解fastjson過濾字段為null值如何解決

    Spring?boot詳解fastjson過濾字段為null值如何解決

    這篇文章主要介紹了解決Spring?boot中fastjson過濾字段為null值的問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • Activiti7與Spring以及Spring Boot整合開發(fā)

    Activiti7與Spring以及Spring Boot整合開發(fā)

    這篇文章主要介紹了Activiti7與Spring以及Spring Boot整合開發(fā),在Activiti中核心類的是ProcessEngine流程引擎,與Spring整合就是讓Spring來管理ProcessEngine,有感興趣的同學(xué)可以參考閱讀
    2023-03-03
  • 解決Java包裝類比較時(shí)遇到的問題

    解決Java包裝類比較時(shí)遇到的問題

    所謂包裝類的作用就是將原始數(shù)據(jù)類型轉(zhuǎn)換成引用數(shù)據(jù)類型,下面這篇文章主要給大家介紹了關(guān)于在Java包裝類比較時(shí)遇到的問題的解決方法,文中給出了詳細(xì)的示例代碼,需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-09-09
  • Java動(dòng)態(tài)代理(設(shè)計(jì)模式)代碼詳解

    Java動(dòng)態(tài)代理(設(shè)計(jì)模式)代碼詳解

    這篇文章主要介紹了Java動(dòng)態(tài)代理(設(shè)計(jì)模式)代碼詳解,具有一定借鑒價(jià)值,需要的朋友可以參考下
    2017-12-12
  • Java異常分類及統(tǒng)一處理詳解

    Java異常分類及統(tǒng)一處理詳解

    這篇文章主要為大家詳細(xì)介紹了Java異常分類及統(tǒng)一處理,SpringMVC處理異常支持ajax,web.xml配置異常,感興趣的小伙伴們可以參考一下
    2016-03-03
  • Java 讀取excel 文件流代碼實(shí)例

    Java 讀取excel 文件流代碼實(shí)例

    這篇文章主要介紹了Java 讀取excel 文件流代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-09-09

最新評論