在撰写技术文档或整理数据时,我们常常需要将 Excel 表格转为 Markdown 格式,以便嵌入到博客、项目文档或 README 中。虽然可以手动转换,但对于批量或重复性任务,自动化显然更高效。本文将展示如何使用 C# 和 Spire.XLS 库,通过一行核心方法快速将 Excel 文件保存为 Markdown 文件。
准备工作
首先,新建一个 C# 控制台项目(.NET Framework 或 .NET 5+ 都行)。
然后打开 NuGet 包管理器,搜索 Spire.XLS 并安装。
或者直接在包管理器控制台敲:
bash
Install-Package Spire.XLS
实现步骤
通过内置的 SaveToMarkdown 方法,可以直接将整个工作簿保存为 Markdown 文件。整个过程只需三步:
-
创建
Workbook对象并加载 Excel 文件。 -
调用
SaveToMarkdown方法保存为.md文件。 -
释放资源。
下面是一个完整的示例代码。
极简代码示例
csharp
using Spire.Xls;
namespace ExcelToMarkdown
{
internal class Program
{
static void Main(string[] args)
{
// 1. 创建 Workbook 对象并加载 Excel 文件
Workbook workbook = new Workbook();
workbook.LoadFromFile("Sample.xlsx"); // 支持 .xls 和 .xlsx
// 2. 将整个工作簿保存为 Markdown 文件
workbook.SaveToMarkdown("output.md");
// 3. 释放资源
workbook.Dispose();
}
}
}
运行后,会在程序输出目录下生成一个 output.md 文件,其中包含了 Excel 中所有工作表的 Markdown 表格(每个工作表用标题分隔)。
关键点说明
1. SaveToMarkdown 方法的行为
-
该方法会将工作簿中的每个非空工作表转换为一个独立的 Markdown 表格,并在表格前添加工作表名称作为标题。
-
表格格式遵循标准 Markdown 语法:第一行为表头(默认使用 Excel 的第一行数据),第二行为分隔行(|---),后续为数据行。
2. 格式丢失怎么办?
转完发现 Excel 里的字体颜色、单元格背景没了?这是正常的,Markdown 表格本身就不支持这些样式,能保留文本和表格结构就够了.
3. 文件路径
可以用相对路径(像上面的示例),也可以用绝对路径,比如 @"C:\data\myfile.xlsx"。如果文件找不到,程序会报错,建议实际使用时加上 try-catch 或者用 File.Exists 先检查一下。
总结
通过以上示例,我们仅用几行代码就完成了 Excel 到 Markdown 的转换,极大简化了开发工作。该方法自动处理了表格结构和多工作表等问题,非常适合快速导出数据。如果对输出格式有特殊要求,也可以结合手动遍历的方式灵活实现。