Java 将Excel转为SVG的方法

网友投稿 244 2023-01-12

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程序(即本文中使用的方法)。

方法2:Maven仓库下载导入。先在maven程序中配置pom.xml文件,如下内容:

com.e-iceblue

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

e-iceblue

spire.xls.free

3.9.1

完成配置后,点击“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> 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项目文件夹下查看,如下图:

另一种方法

同样使用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 shttp://tatic 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.getOutputShttp://tream(), sheet.getFirstRow(), sheet.getFirstColumn(),

sheet.getLastRow(), sheet.getLastColumn());

} catch (Exception e) {

e.printStackTrace();

}

}

}

生成svg服务

public void generateSVG(ReportRequest request, HttpServletResponse response) throws Exception {

ServiceResult> result = getOperationRepohbCVrWrt(request);

if (result != null && result.isSucceed() && !CollectionUtils.isEmpty(result.getData())) {

//转为map

List> 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的方法的详细内容,更多关于Java 将Excel转为SVG的资料请关注我们其它相关文章!

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:福建中日快递物流查询单号(福建中日快递物流查询单号官网)
下一篇:浅谈IDEA实用的Servlet模板
相关文章

 发表评论

暂时没有评论,来抢沙发吧~