国产化Excel处理组件Spire.XLS教程:使用 Java 将 CSV 转换为 Excel

将 CSV 文件转换为 Excel 是 Java 开发者在进行数据报表、分析流程或文件转换时常见的操作。虽然可以手动解析 CSV 文件,但这种方式不仅代码繁琐,而且格式控制能力有限。借助如 **++Spire.XLS for Java++**这样的专业 Excel 库,可以极大简化处理流程,同时实现对布局、样式、模板以及数据整合的全面控制。

E -iceblue 旗下Spire系列产品,是文档处理领域的佼佼者,支持国产化信创 本文将带你逐步了解多种使用场景,介绍如何借助**++Spire.XLS for Java++** 使用 Java 将 CSV 转换为 Excel,包括基本的导入导出、样式设置、注入模板数据、以及将多个 CSV 文件合并为一个 Excel 工作簿等内容。

Spire.XLS for Java免费试用下载

在 Java 项目中配置 Spire.XLS

在进行 CSV 到 Excel 的转换前,需要将 ++Spire.XLS for Java++ 引入到项目中。该库支持 .xls 与 .xlsx 文件格式,并提供简洁的 API,无需安装 Microsoft Office 即可创建和操作 Excel 文档。

通过 Maven 引入

复制代码
<repositories>
    <repository>
        <id>com.e-iceblue</id>
        <name>e-iceblue</name>
        <url>https://repo.e-iceblue.cn/repository/maven-public/</url>
    </repository>
</repositories>
<dependencies>
    <dependency>
        <groupId>e-iceblue</groupId>
        <artifactId>spire.xls</artifactId>
        <version>15.7.7</version>
    </dependency>
</dependencies>

手动引入 JAR 包

你也可以**++下载 Spire.XLS for Java++**,并手动将 JAR 文件添加到项目的类路径中。

使用 Java 将 CSV 文件转换为 Excel

最基本的使用场景是将一个 .csv 文件转换为 .xlsx 或 .xls 格式。使用**++Spire.XLS++**,只需两步即可完成:使用 loadFromFile() 加载 CSV,使用 saveToFile() 保存为 Excel 文件。

复制代码
import com.spire.xls.*;

public class CsvToXlsx {
    public static void main(String[] args) {
        Workbook workbook = new Workbook();
        workbook.loadFromFile("data.csv", ",");
        workbook.saveToFile("output.xlsx", ExcelVersion.Version2013);
    }
}

若要输出为 .xls 格式,只需将版本参数改为 ExcelVersion.Version97to2003。

以下是转换结果示意图:

此外,你还可以自定义分隔符,或设置起始的行和列位置,非常适合已有标题或固定布局的场景:

复制代码
workbook.loadFromFile("data_semicolon.csv", ";", 3, 2);

使用 Java 设置 Excel 输出格式

在生成用于报表或客户展示的 Excel 文件时,设置样式能显著提升可读性与专业感。++Spire.XLS++ 支持通过 CellStyle 类自定义字体、颜色、数字格式等,并支持自动调整列宽。

示例:设置样式并自动调整列宽

复制代码
import com.spire.xls.*;

public class CsvToXlsx {
    public static void main(String[] args) {
        Workbook workbook = new Workbook();
        workbook.loadFromFile("data.csv", ",");

        Worksheet sheet = workbook.getWorksheets().get(0);

        // 设置表头样式
        CellStyle headerStyle = workbook.getStyles().addStyle("Header");
        headerStyle.getFont().isBold(true);
        headerStyle.getFont().setSize(14f);
        headerStyle.setKnownColor(ExcelColors.LightYellow);
        for (int col = 1; col <= sheet.getLastColumn(); col++) {
            sheet.getCellRange(1, col).setStyle(headerStyle);
        }

        // 设置数字列样式
        CellStyle numStyle = workbook.getStyles().addStyle("Numbers");
        numStyle.setNumberFormat("#,##0.00");
        sheet.getCellRange("B2:B100").setStyle(numStyle);

        // 统一设置字体自动调整列宽
        sheet.getRange().getStyle().getFont().setFontName("微软雅黑");
        for (int i = 1; i <= sheet.getLastRow(); i++) {
            sheet.autoFitColumn(i);
        }

        workbook.saveToFile("formatted_output.xlsx", ExcelVersion.Version2013);
    }
}

以下是带有格式的 Excel 输出示例:

如果你想将数据导入到预设的 Excel 模板中,只需加载现有 .xlsx 文件,并使用如 insertArray() 插入数组。请注意,模板格式不会自动应用,仍需手动设置样式。

将多个 CSV 文件合并为一个 Excel 文件

当处理批量数据或多个来源的数据时,通常需要将多个 CSV 文件合并为一个 Excel 文件。++Spire.XLS++ 支持以下两种方式:

  • 每个 CSV 文件导入到独立的工作表;
  • 所有 CSV 数据整合到同一个工作表中。

方式一:每个 CSV 单独作为工作表

复制代码
import com.spire.xls.*;
import java.io.File;

public class CsvToXlsx {
    public static void main(String[] args) {
        File[] csvFiles = new File("CSVs/").listFiles((dir, name) -> name.endsWith(".csv"));
        Workbook workbook = new Workbook();
        workbook.getWorksheets().clear();

        for (File csv : csvFiles) {
            Workbook temp = new Workbook();
            temp.loadFromFile(csv.getAbsolutePath(), ",");
            workbook.getWorksheets().addCopy(temp.getWorksheets().get(0));
        }

        workbook.saveToFile("merged.xlsx", ExcelVersion.Version2016);
    }
}

下图展示了多个工作表组成的 Excel 文件:

方式二:将所有数据合并到同一个工作表中

复制代码
import com.spire.xls.*;
import java.io.File;

public class CsvToXlsx {
    public static void main(String[] args) {
        File[] csvFiles = new File("CSVs/").listFiles((dir, name) -> name.endsWith(".csv"));
        Workbook workbook = new Workbook();
        workbook.getWorksheets().clear();
        Worksheet sheet = workbook.getWorksheets().add("Sample");

        int startRow = 1;
        boolean isFirstFile = true;

        for (File csv : csvFiles) {
            Workbook temp = new Workbook();
            temp.loadFromFile(csv.getAbsolutePath(), ",");
            Worksheet tempSheet = temp.getWorksheets().get(0);

            int startReadRow = isFirstFile ? 1 : 2;
            isFirstFile = false;

            for (int r = startReadRow; r <= tempSheet.getLastRow(); r++) {
                for (int c = 1; c <= tempSheet.getLastColumn(); c++) {
                    sheet.getCellRange(startRow, c).setValue(tempSheet.getCellRange(r, c).getText());
                }
                startRow++;
            }
        }

        workbook.saveToFile("merged_single_sheet.xlsx", ExcelVersion.Version2016);
    }
}

以下是合并结果的截图:

故障排查建议

错误及解决方法:

  • Excel 内容乱码?

请确保 CSV 文件采用 UTF-8 编码。

  • 列错位或对齐不正确?

检查使用的分隔符是否一致。

  • CSV 文件过大?

考虑将其拆分为多个工作表,提高处理效率。

  • 合并的文件结构不同?

先统一字段结构或列标题,再执行合并操作。

常见问题解答

如何在 Java 中将 CSV 文件转换为 XLSX 格式?

使用 Workbook.loadFromFile("file.csv", ",") 加载 CSV 文件,然后使用 saveToFile("output.xlsx", ExcelVersion.Version2016) 保存为 .xlsx 文件。

可以设置 Excel 输出的样式吗?

可以。通过 CellStyle 类可设置字体、颜色、对齐方式、数字格式等。

可以将 CSV 数据插入到 Excel 模板中吗?

完全可以。加载 .xlsx 模板文件后,通过 setText() 或 insertDataTable() 方法注入数据。

如何将多个 CSV 文件合并为一个 Excel 文件?

可以选择每个 CSV 为一个工作表,或将它们逐行追加合并到一个工作表中。

相关推荐
站大爷IP1 分钟前
用PyQt快速搭建桌面应用:从零到实战的实用指南
python
忘带键盘了10 分钟前
Dish、DishVO 和 DishDTO
java
站大爷IP13 分钟前
PyCharm:Python开发者的智慧工作台全解析
python
zhanghongyi_cpp19 分钟前
linux的conda配置与应用阶段的简单指令备注
linux·python·conda
MThinker23 分钟前
14.examples\01-Micropython-Basics\demo_yield.py 加强版
python·学习·智能硬件·micropython·canmv·k230
SimonKing28 分钟前
Spring Boot Admin:一站式监控微服务,这个运维神器真香!
java·后端·程序员
LiRuiJie43 分钟前
基于LangChain + Milvus 实现RAG
python·langchain·milvus·rag
RainbowSea1 小时前
1. LangChain4J 理论概述
java·langchain·llm
刘 大 望1 小时前
网络编程--TCP/UDP Socket套接字
java·运维·服务器·网络·数据结构·java-ee·intellij-idea
没有bug.的程序员2 小时前
AOT 编译与 GraalVM 实战:Java 云原生的终极进化
java·python·云原生·graalvm·aot