Java 將Excel轉(zhuǎn)為SVG的方法
1. 程序運(yùn)行環(huán)境如下:
編譯工具:IDEA
JDK版本:1.8.0
Excel測(cè)試文檔:.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倉(cāng)庫(kù)下載導(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測(cè)試文檔
Workbook workbook = new Workbook();
workbook.loadFromFile("sample.xlsx");
int count = 1;
//獲取分頁(yè)信息
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);//獲取每頁(yè)sheet的分頁(yè)信息
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的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
- java生成餅圖svg及JFreeChart生成svg圖表
- Java基于Spire Cloud Excel把Excel轉(zhuǎn)換成PDF
- Java實(shí)現(xiàn)Word/Excel/TXT轉(zhuǎn)PDF的方法
- java實(shí)現(xiàn)在線預(yù)覽--poi實(shí)現(xiàn)word、excel、ppt轉(zhuǎn)html的方法
- Java使用jacob將微軟office中word、excel、ppt轉(zhuǎn)成pdf
- java 讀取excel文件轉(zhuǎn)換成json格式的實(shí)例代碼
- Java實(shí)現(xiàn)的Excel列號(hào)數(shù)字與字母互相轉(zhuǎn)換功能
- Java實(shí)現(xiàn)excel表格轉(zhuǎn)成json的方法
- java 中Excel轉(zhuǎn)shape file的實(shí)例詳解
- java實(shí)現(xiàn)excel和txt文件互轉(zhuǎn)
- java POI解析Excel 之?dāng)?shù)據(jù)轉(zhuǎn)換公用方法(推薦)
- Java實(shí)現(xiàn)把excel xls中數(shù)據(jù)轉(zhuǎn)為可直接插入數(shù)據(jù)庫(kù)的sql文件
相關(guān)文章
SpringBoot整合kafka遇到的版本不對(duì)應(yīng)問(wèn)題及解決
這篇文章主要介紹了SpringBoot整合kafka遇到的版本不對(duì)應(yīng)問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03
如何實(shí)現(xiàn)自己的spring boot starter
這篇文章主要介紹了如何實(shí)現(xiàn)自己的spring boot starter,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-08-08
java中JVM中如何存取數(shù)據(jù)和相關(guān)信息詳解
這篇文章主要介紹了JVM中如何存取數(shù)據(jù)和相關(guān)信息詳解,Java源代碼文件(.java后綴)會(huì)被Java編譯器編譯為字節(jié)碼文件,然后由JVM中的類加載器加載各個(gè)類的字節(jié)碼文件,加載完畢之后,交由JVM執(zhí)行引擎執(zhí)行。JVM中怎么存取數(shù)據(jù)和相關(guān)信息呢?,需要的朋友可以參考下2019-06-06
Java實(shí)現(xiàn)經(jīng)典俄羅斯方塊游戲
俄羅斯方塊是一個(gè)最初由阿列克謝帕吉特諾夫在蘇聯(lián)設(shè)計(jì)和編程的益智類視頻游戲。本文將利用Java實(shí)現(xiàn)這一經(jīng)典的小游戲,需要的可以參考一下2022-01-01
Java分別利用深度優(yōu)先和廣度優(yōu)先求解迷宮路徑
這篇文章主要為大家詳細(xì)介紹了Java如何利用深度優(yōu)先的非遞歸遍歷方法和廣度優(yōu)先的遍歷方法實(shí)現(xiàn)求解迷宮路徑,文中的示例代碼講解詳細(xì),需要的可以參考一下2022-08-08
Hibernate實(shí)現(xiàn)悲觀鎖和樂觀鎖代碼介紹
這篇文章主要介紹了Hibernate實(shí)現(xiàn)悲觀鎖和樂觀鎖的有關(guān)內(nèi)容,涉及hibernate的隔離機(jī)制,以及實(shí)現(xiàn)悲觀鎖和樂觀鎖的代碼實(shí)現(xiàn),需要的朋友可以了解下。2017-09-09
分享一個(gè)你不知道的Java異常實(shí)現(xiàn)的缺陷
Java中一個(gè)大家熟知的知識(shí)點(diǎn)就是異常捕獲,try...catch...finally組合,但是很多人不知道這里面有一個(gè)關(guān)于Java的缺陷,或者說(shuō)是異常實(shí)現(xiàn)的一點(diǎn)不足之處。本文就通過(guò)一個(gè)很簡(jiǎn)單的實(shí)驗(yàn)給大家演示下效果玩玩兒,希望大家能覺得有趣2022-12-12
Java設(shè)計(jì)模式之java狀態(tài)模式詳解
這篇文章主要介紹了Java設(shè)計(jì)模式之狀態(tài)模式定義與用法,結(jié)合具體實(shí)例形式詳細(xì)分析了Java狀態(tài)模式的概念、原理、定義及相關(guān)操作技巧,需要的朋友可以參考下2021-09-09

