中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Java如何將Excel轉為SVG

發布時間:2021-05-31 10:00:53 來源:億速云 閱讀:174 作者:小新 欄目:開發技術

小編給大家分享一下Java如何將Excel轉為SVG,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

1. 程序運行環境如下:

編譯工具:IDEA

JDK版本:1.8.0

Excel測試文檔:.xlsx 2013

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

2.關于如何導入jar包

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

Java如何將Excel轉為SVG

方法2:Maven倉庫下載導入。先在maven程序中配置pom.xml文件,如下內容:

<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>

完成配置后,點擊“Import”下載導入。

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();
            }
        }

    }
}

轉換結果可在IDEA項目文件夾下查看,如下圖:

Java如何將Excel轉為SVG

另一種方法

同樣使用Free-Spire-XLS 

依賴引入同上

轉換工具類

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轉換處理工具類:轉為圖片、svg文件等
 *
 * @author yangfeng
 * @date 2019-12-26
 */
public class ExcelTransformUtil {
 
    /**
     * workbook 轉為輸入流
     *
     * @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 轉為圖片
     *
     * @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 轉為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服務

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

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

以上是“Java如何將Excel轉為SVG”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

海南省| 滨州市| 内江市| 绥化市| 惠水县| 鄢陵县| 黄石市| 崇左市| 庆元县| 南昌县| 深泽县| 沙田区| 土默特右旗| 廉江市| 中牟县| 蒙城县| 盐津县| 大庆市| 任丘市| 土默特右旗| 疏附县| 仙游县| 永丰县| 江西省| 祁门县| 河西区| 岳阳市| 成都市| 黄大仙区| 攀枝花市| 米易县| 西吉县| 临湘市| 双城市| 台湾省| 兴业县| 治县。| 阜康市| 彭泽县| 三台县| 睢宁县|