C#教程
主页 > 软件编程 > C#教程 >

C# Spire.XLS for .NET轻松实现Excel到TXT的转换

2025-12-22 | 佚名 | 点击:

在数据处理领域,Excel文件以其强大的功能占据着举足轻重的地位。然而,在诸多应用场景下,我们却需要将这些结构化的Excel数据转换为更为简洁、通用的文本文件(TXT)。这背后往往隐藏着数据清洗、导入旧系统、简化数据结构、或进行特定文本分析等需求。传统的复制粘贴不仅效率低下,还容易引入格式错误;而使用ADO.NET等方式虽然可行,但配置繁琐,对Office环境的依赖也令人头疼。

今天,我将通过一个高效且功能强大的第三方库——Spire.XLS for .NET,帮助C#开发者轻松实现Excel到TXT的转换,告别上述痛点,让数据处理变得前所未有的便捷。

为什么选择Spire.XLS for .NET进行Excel转TXT

在深入代码之前,我们先来聊聊为什么Spire.XLS for .NET是这个任务的理想选择。

相比手动复制粘贴的低效与错误率,或ADO.NET需要配置数据源和连接字符串的复杂性,Spire.XLS for .NET以其专业性和简洁性,在Excel数据提取方面显得尤为突出。

核心实现:C#中Excel转TXT的步骤

接下来,我们将通过详细的步骤和可运行的代码示例,展示如何使用Spire.XLS for .NET将Excel文件转换为TXT。

步骤一:安装Spire.XLS for .NET

首先,您需要将Spire.XLS for .NET库添加到您的C#项目中。最便捷的方式是通过NuGet包管理器:

1

Install-Package Spire.XLS

或者在Visual Studio中右键项目 -> “管理NuGet程序包” -> 搜索“Spire.XLS”并安装。

步骤二:编写C#代码实现转换

以下是一个完整的C#代码示例,演示了如何加载一个Excel文件,并将其第一个工作表的内容转换为一个以空格分隔的TXT文件。

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

using Spire.Xls;

using System.Text;

using System.IO;

 

public class ExcelToTextConverter

{

    public static void ConvertExcelToTxt(string excelFilePath, string outputTxtPath, string delimiter = " ", Encoding encoding = null)

    {

        // 确保指定了默认编码,如果未提供

        if (encoding == null)

        {

            encoding = Encoding.UTF8; // 默认使用UTF-8编码

        }

 

        // 1. 创建Workbook对象并加载Excel文件

        Workbook workbook = new Workbook();

        try

        {

            workbook.LoadFromFile(excelFilePath);

            Console.WriteLine($"成功加载Excel文件: {excelFilePath}");

 

            // 2. 获取第一个工作表(您可以根据需要选择其他工作表)

            Worksheet sheet = workbook.Worksheets[0];

            Console.WriteLine($"正在处理工作表: {sheet.Name}");

 

            // 3. 将工作表内容保存为TXT文件

            // SaveToFile方法提供了直接将工作表保存为文本的功能

            // 参数1: 输出TXT文件路径

            // 参数2: 数据分隔符(例如:空格、逗号、制表符"\t")

            // 参数3: 文本文件编码,防止中文乱码

            sheet.SaveToFile(outputTxtPath, delimiter, encoding);

 

            Console.WriteLine($"Excel文件已成功转换为TXT文件: {outputTxtPath}");

        }

        catch (Exception ex)

        {

            Console.WriteLine($"转换过程中发生错误: {ex.Message}");

            Console.WriteLine(ex.StackTrace);

        }

        finally

        {

            // 4. 释放资源

            workbook.Dispose();

        }

    }

 

    public static void Main(string[] args)

    {

        // 示例用法

        string inputExcel = "SampleData.xlsx"; // 确保此文件存在于项目根目录或指定完整路径

        string outputText = "OutputData.txt";

 

        // 创建一个简单的Excel文件用于测试 (如果SampleData.xlsx不存在)

        CreateSampleExcelFile(inputExcel);

 

        // 调用转换方法

        ConvertExcelToTxt(inputExcel, outputText, ",", Encoding.UTF8); // 使用逗号分隔,UTF-8编码

 

        Console.WriteLine("\n按任意键退出...");

        Console.ReadKey();

    }

 

    // 辅助方法:创建一个简单的Excel文件用于测试

    private static void CreateSampleExcelFile(string fileName)

    {

        if (!File.Exists(fileName))

        {

            Workbook workbook = new Workbook();

            Worksheet sheet = workbook.Worksheets[0];

            sheet.Name = "Sheet1";

 

            sheet.Range["A1"].Value = "姓名";

            sheet.Range["B1"].Value = "年龄";

            sheet.Range["C1"].Value = "城市";

 

            sheet.Range["A2"].Value = "张三";

            sheet.Range["B2"].NumberValue = 30;

            sheet.Range["C2"].Value = "北京";

 

            sheet.Range["A3"].Value = "李四";

            sheet.Range["B3"].NumberValue = 25;

            sheet.Range["C3"].Value = "上海";

 

            sheet.Range["A4"].Value = "王五";

            sheet.Range["B4"].NumberValue = 35;

            sheet.Range["C4"].Value = "广州";

 

            workbook.SaveToFile(fileName, ExcelVersion.Version2013);

            workbook.Dispose();

            Console.WriteLine($"已创建示例Excel文件: {fileName}");

        }

    }

}

代码解释:

步骤三:关键参数与注意事项

进阶应用与性能优化

数据提取的灵活性: 如果您只需要转换Excel中的特定区域或特定列,Spire.XLS也提供了丰富的API。例如,您可以先遍历工作表中的Range对象,然后根据条件筛选数据,最后手动构建字符串并写入TXT文件。

1

2

3

4

5

6

7

8

9

// 示例:只提取A列和B列的数据

StringBuilder sb = new StringBuilder();

for (int row = 1; row <= sheet.LastRow; row++)

{

    string cellAValue = sheet.Range[row, 1].Text; // A列

    string cellBValue = sheet.Range[row, 2].Text; // B列

    sb.AppendLine($"{cellAValue},{cellBValue}");

}

File.WriteAllText(outputTxtPath, sb.ToString(), encoding);

处理大型文件: 对于包含数十万甚至数百万行数据的大型Excel文件,直接将整个工作表加载到内存可能会导致内存溢出。Spire.XLS for .NET在设计上对性能有所优化,但如果遇到极端情况,可以考虑以下策略:

总结与展望

通过本文的介绍,相信您应该已经掌握了在C#中使用Spire.XLS for .NET将Excel文件高效转换为TXT文件的方法。这个库不仅让转换过程变得异常简单,更重要的是,它解除了对Office环境的依赖,提供了强大的兼容性和灵活性,是C#开发者处理Excel数据的利器。

在数据驱动的今天,自动化和效率是衡量开发工作质量的重要标准。掌握这样的工具,能让您在面对各种数据处理需求时游刃有余。大家也可以动手尝试,并探索Spire.XLS for .NET的更多强大功能,它将为您的C#项目带来意想不到的便利和价值!

原文链接:
相关文章
最新更新