Java 將Excel轉(zhuǎ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)文章!
- 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列號數(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ù)庫的sql文件
相關(guān)文章
Java使用Spring發(fā)送郵件的實(shí)現(xiàn)代碼
本篇文章主要介紹了使用Spring發(fā)送郵件的實(shí)現(xiàn)代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-03-03Gradle jvm插件系列教程之Java?Library插件權(quán)威詳解
這篇文章主要介紹了Java?Library插件權(quán)威詳解,本文通過示例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2024-01-01Spring?boot詳解fastjson過濾字段為null值如何解決
這篇文章主要介紹了解決Spring?boot中fastjson過濾字段為null值的問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-07-07Activiti7與Spring以及Spring Boot整合開發(fā)
這篇文章主要介紹了Activiti7與Spring以及Spring Boot整合開發(fā),在Activiti中核心類的是ProcessEngine流程引擎,與Spring整合就是讓Spring來管理ProcessEngine,有感興趣的同學(xué)可以參考閱讀2023-03-03Java動(dòng)態(tài)代理(設(shè)計(jì)模式)代碼詳解
這篇文章主要介紹了Java動(dòng)態(tài)代理(設(shè)計(jì)模式)代碼詳解,具有一定借鑒價(jià)值,需要的朋友可以參考下2017-12-12