Java实现XLS和XLSX之间的相互转换

本文介绍了如何在Java中利用Spire.XLS for Java库进行XLS到XLSX以及XLSX到XLS的转换。文章详细展示了转换过程中的代码示例和转换效果。
摘要由CSDN通过智能技术生成


前言

当你在较新版本的Microsoft Excel中打开一个XLS文件,如Excel 2016或2019,你会在文件名后的标题栏中看到 “兼容模式”。如果你想从兼容模式改为正常模式,你可以把XLS文件保存为较新的Excel文件格式,如XLSX。由于版本的不同,我们有时需要将其中一种转换为另一种。在这篇文章中,你将学习如何在Java中使用Spire.XLS for Java将XLS转换为XLSX或XLSX转换为XLS。附,XLS和XLSX的区别


一、程序环境

安装Spire.XLS for Java
首先,您需要在Java程序中添加Spire.Xls.jar文件作为一个依赖项。您可以从这个链接下载JAR文件。如果您使用Maven,则可以通过在pom.xml文件中添加以下代码轻松导入该JAR文件。

<repositories>
    <repository>
        <id>com.e-iceblue</id>
        <name>e-iceblue</name>
        <url> http
  • 1
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
Java可以通过使用Apache POI库来实现xls文件转换xlsx文件。 首先,我们需要在Java项目中引入Apache POI的相关依赖项。在maven项目中,可以在pom.xml文件中添加以下依赖项: ``` <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi</artifactId> <version>4.1.2</version> </dependency> <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi-ooxml</artifactId> <version>4.1.2</version> </dependency> ``` 接下来,我们可以使用以下代码来实现xls文件转换xlsx文件: ```java import org.apache.poi.ss.usermodel.*; import org.apache.poi.xssf.usermodel.XSSFWorkbook; import org.apache.poi.hssf.usermodel.HSSFWorkbook; import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.IOException; public class ExcelConverter { public static void main(String[] args) { String inputFile = "input.xls"; // 输入的xls文件路径 String outputFile = "output.xlsx"; // 输出的xlsx文件路径 try { FileInputStream inputStream = new FileInputStream(inputFile); Workbook inputWorkbook = new HSSFWorkbook(inputStream); // 创建xls工作簿 Workbook outputWorkbook = new XSSFWorkbook(); // 创建xlsx工作簿 int numberOfSheets = inputWorkbook.getNumberOfSheets(); // 获取xls中的工作表数量 for (int i = 0; i < numberOfSheets; i++) { Sheet inputSheet = inputWorkbook.getSheetAt(i); // 获取xls中的一个工作表 Sheet outputSheet = outputWorkbook.createSheet(inputSheet.getSheetName()); // 创建对应的工作表到xlsx文件中 int rowCount = inputSheet.getLastRowNum(); for (int j = 0; j <= rowCount; j++) { Row inputRow = inputSheet.getRow(j); // 获取xls中的一行数据 Row outputRow = outputSheet.createRow(j); // 创建对应的行到xlsx文件中 int cellCount = inputRow.getLastCellNum(); for (int k = 0; k < cellCount; k++) { Cell inputCell = inputRow.getCell(k); // 获取xls中的一个单元格 Cell outputCell = outputRow.createCell(k); // 创建对应的单元格到xlsx文件中 outputCell.setCellValue(inputCell.getStringCellValue()); // 将xls单元格的值复制到xlsx单元格 } } } FileOutputStream outputStream = new FileOutputStream(outputFile); outputWorkbook.write(outputStream); // 将xlsx工作簿保存到文件中 outputStream.close(); inputWorkbook.close(); outputWorkbook.close(); System.out.println("转换成功!"); } catch (IOException e) { e.printStackTrace(); } } } ``` 以上代码将读取名为"input.xls"的xls文件,将其内容复制到一个新创建的名为"output.xlsx"的xlsx文件中。转换完成后,控制台将输出"转换成功!"。 这就是使用Javaxls文件转换xlsx文件的基本步骤。你可以根据需要进行进一步的定制和优化。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值