c语言sscanf函数的用法是什么
234
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文件,如下内容:
完成配置后,点击“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
//遍历工作表
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
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小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~