Python 高效实现 Excel 转 TXT 文本

基础示例:单工作表 Excel 转 TXT

以下是将一个 Excel 文件中的第一个工作表转换为 TXT 的完整步骤:

1. 加载并读取Excel文件

复制代码
from spire.xls import *
from spire.xls.common import *

workbook = Workbook()
workbook.LoadFromFile("示例.xlsx")

2. 执行转换并保存

复制代码
sheet = workbook.Worksheets[0]
sheet.SaveToFile("output.txt", "\t", Encoding.get_UTF8())

参数说明

参数类型 示例值 描述
分隔符 \t (制表符) 定义 TXT 文件中各列数据之间的分隔方式,也可使用逗号 ,、分号 ; 等。
编码方式 Encoding.get_UTF8()(国际通用编码) 指定文本文件的编码格式,推荐使用 UTF-8 以保证中文等字符正常显示。

进阶处理:多工作表分别导出为 TXT

如果你的 Excel 文件包含多个工作表,并且希望将每个工作表保存为单独的 TXT 文件,可以使用以下代码:

复制代码
from spire.xls import *
from spire.xls.common import *

def excel_sheets_to_txt(input_file, output_folder, delimiter="\t"):
  
    # 创建Workbook对象
    workbook = Workbook()
    # 加载Excel文件
    workbook.LoadFromFile(input_file)
        
    # 遍历所有工作表
    for i in range(workbook.Worksheets.Count):
        sheet = workbook.Worksheets[i]
            
        # 构建输出文件路径
        output_file = f"sheet_{i+1}_{sheet.Name}.txt"
        output_path = os.path.join(output_folder, output_file)
            
        # 将工作表内容保存为TXT文件
        sheet.SaveToFile(output_path, delimiter, Encoding.get_UTF8())

Excel 转 TXT 在自动化流程中的应用

将 Excel 转换为 TXT 不仅是格式的简单转换,更是实现数据自动化流程的重要环节。结合 Spire.XLS for Python,可轻松构建以下应用:

  • 自动化报告生成: 从 Excel 模板中提取数据,生成纯文本格式的报告摘要,方便邮件发送或系统集成。
  • 数据清洗与预处理: 将复杂格式的 Excel 数据转换为 TXT,作为其他数据分析工具(如Spark、Hadoop)的输入源,进行更深层次的处理。
  • 配置管理: 将 Excel 中维护的系统配置、参数表等导出为 TXT 格式,便于脚本直接读取,同时更适合使用 Git 等工具进行版本管理。
相关推荐
手握风云-1 分钟前
Spring AI:让大模型住进 Spring 生态(五)
java·后端·spring
plainGeekDev2 分钟前
Timer → Coroutines
android·java·kotlin
糖果店的幽灵5 分钟前
Spring AI 从入门到精通-Spring AI 是什么
java·人工智能·spring
XiYang-DING6 分钟前
【Java EE】TOCTOU
java·java-ee
.千余7 分钟前
【C++】 String 常用操作:增删查改 | 查找 | 截取 | IO
java·服务器·开发语言·c++·笔记·学习
长栎8 分钟前
面试官说你的单例线程不安全,你真能现场修好?
java
码云骑士9 分钟前
【Java基础】JDK安装常见问题教辅-从踩坑到排雷
java·开发语言
Sunia13 分钟前
《AgentX 专栏》09-MCP协议双向打通:让AgentX既能被Claude调用又能调度全球工具生态
java·架构
wyu7296117 分钟前
SpringBoot八股的一些概念笔记
java·面试
KaMeidebaby17 分钟前
卡梅德生物技术快报|细胞周期检测抗原流式分析:参数调试、软件拟合与问题排查
网络·人工智能·python·网络协议·tcp/ip·算法·机器学习