Python 实现 CSV 转 TXT 格式 (单文件 + 批量处理)

在数据处理、报表归档和跨平台数据传输场景中,CSV格式因结构简洁、易与表格软件兼容而被广泛使用,但TXT格式具有更强的通用性、更低的存储冗余,且无需专用软件即可打开查看。本文将详细介绍如何使用 Free Spire.XLS for Python 免费库实现 CSV 到 TXT 的格式转换,涵盖单文件转换和批量文件夹转换两种核心场景,解决中文乱码、数据结构错乱等常见问题。

文章目录

    • [一、安装免费 Python 库](#一、安装免费 Python 库)
      • [1. 核心安装命令](#1. 核心安装命令)
      • [2. 备用安装方案(若 pip 安装失败)](#2. 备用安装方案(若 pip 安装失败))
      • [3. 注意事项](#3. 注意事项)
    • [二、CSV 转 TXT 文本文件的核心逻辑](#二、CSV 转 TXT 文本文件的核心逻辑)
    • [三、案例1:单个 CSV 文件转 TXT 格式](#三、案例1:单个 CSV 文件转 TXT 格式)
    • [四、案例2:批量转换文件夹下所有 CSV 文件](#四、案例2:批量转换文件夹下所有 CSV 文件)
    • 五、总结与拓展

一、安装免费 Python 库

Free Spire.XLS for Python 是一款功能强大的Excel/CSV处理库,无需依赖Microsoft Excel环境,支持CSV文件的读取、解析和格式转换,且使用免费。首先需要完成库的安装,推荐使用pip命令快速部署:

1. 核心安装命令

bash 复制代码
pip install Spire.Xls.Free

2. 备用安装方案(若 pip 安装失败)

如果遇到网络超时或版本兼容问题,可以前往 Spire 官方下载页面下载 .whl 文件,通过本地文件安装:

bash 复制代码
pip install 本地文件路径/Spire.XLS-for-Python-x.x.x-py3-none-xxxx.whl

3. 注意事项

  • 支持Python 3.6及以上版本;
  • 免费版对单个文件的处理行数有一定限制(满足常规小型数据处理需求);
  • 安装完成后,直接导入Spire.Xls即可使用核心功能。

二、CSV 转 TXT 文本文件的核心逻辑

使用 Free Spire.XLS for Python 实现 CSV 转 TXT 的核心流程清晰易懂,无需复杂的解析逻辑,库已封装好 CSV 文件的读取接口,核心步骤如下:

  1. 创建 Workbook 对象(工作簿),用于承载 CSV 文件数据;
  2. 调用 Workbook.LoadFromFile() 方法加载目标 CSV 文件,指定正确编码避免中文乱码;
  3. 获取 CSV 文件对应的工作表(Worksheet),CSV 加载后默认生成单个工作表;
  4. 调用 Worksheet.SaveToFile() 方法将 CSV 另存为 TXT 文本格式,自定义数据分隔格式及编码;
  5. 释放资源,完成转换。

三、案例1:单个 CSV 文件转 TXT 格式

本案例实现单个 CSV 文件的转换,保留原 CSV 的列分隔结构,解决中文乱码问题,代码可直接运行。

完整代码实现:

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

def csv_to_txt_single(csv_file_path: str, txt_file_path: str):
    """
    单个CSV文件转换为TXT文件
    :param csv_file_path: 输入CSV文件路径(绝对路径/相对路径)
    :param txt_file_path: 输出TXT文件路径(绝对路径/相对路径)
    """
    try:
        # 1. 创建Workbook对象
        workbook = Workbook()

        # 2. 加载CSV文件
        workbook.LoadFromFile(csv_file_path, ",")

        # 3. 获取第一个工作表(CSV文件加载后仅生成一个工作表)
        worksheet = workbook.Worksheets[0]
        
        # 4. 保存为TXT文本文件,并指定分隔符和编码
        worksheet.SaveToFile(txt_file_path, " ", Encoding.get_UTF8())
        workbook.Dispose()

        print(f"单个CSV转换成功!TXT文件保存路径:{txt_file_path}")

    except Exception as e:
        print(f"单个CSV转换失败:{str(e)}")
    finally:
        # 6. 释放工作簿资源,避免内存泄漏
        workbook.Dispose()

# 调用函数执行转换(替换为你的CSV文件路径和目标TXT路径)
if __name__ == "__main__":
    input_csv = "示例.csv"
    output_txt = "result.txt"
    csv_to_txt_single(input_csv, output_txt)

转换效果预览:


四、案例2:批量转换文件夹下所有 CSV 文件

在实际工作中,常需要处理一个文件夹下的多个 CSV 文件,此时可结合os模块遍历文件夹,批量调用单文件转换逻辑,提升处理效率。

完整代码实现:

python 复制代码
from spire.xls import *
from spire.xls.common import *
import os  # 导入os模块用于文件夹遍历和路径处理

def csv_to_txt_single(csv_file_path: str, txt_file_path: str):
    """
    单个CSV文件转换为TXT文件
    :param csv_file_path: 输入CSV文件路径
    :param txt_file_path: 输出TXT文件路径
    """

    try:
        # 1. 创建Workbook对象
        workbook = Workbook()

        # 2. 加载CSV文件(指定逗号作为列分隔符)
        workbook.LoadFromFile(csv_file_path, ",")

        # 3. 获取第一个工作表(CSV加载后仅生成一个工作表)
        worksheet = workbook.Worksheets[0]
        
        # 4. 保存为TXT文件,使用传入的合法输出路径,修正编码方法命名
        worksheet.SaveToFile(txt_file_path, " ", Encoding.get_UTF8())

        print(f"转换成功:{os.path.basename(csv_file_path)} -> {os.path.basename(txt_file_path)}")
    
    # 修正:except与try同级对齐,块内代码缩进一级
    except Exception as e:
        print(f"转换失败:{os.path.basename(csv_file_path)} - {str(e)}")
    
    # 修正:finally与try/except同级对齐,块内代码缩进一级
    finally:
        # 释放工作簿资源,避免内存泄漏(增加非空判断)
        workbook.Dispose()

def csv_to_txt_batch(csv_folder_path: str, txt_folder_path: str):
    """
    批量转换指定文件夹下所有CSV文件为TXT文件
    :param csv_folder_path: 输入CSV文件夹路径
    :param txt_folder_path: 输出TXT文件夹路径
    """
    # 新增:检查输入文件夹是否存在,不存在则直接提示并退出
    if not os.path.exists(csv_folder_path):
        print(f"错误:输入文件夹不存在!路径:{csv_folder_path}")
        return
    
    # 1. 检查输出文件夹是否存在,不存在则创建(避免写入文件时报错)
    if not os.path.exists(txt_folder_path):
        os.makedirs(txt_folder_path)
        print(f"输出文件夹不存在,已创建:{txt_folder_path}")

    # 2. 遍历CSV文件夹,筛选所有.csv后缀文件(忽略大小写,兼容.CSV)
    for file_name in os.listdir(csv_folder_path):
        if file_name.lower().endswith(".csv"):
            # 3. 拼接完整的CSV输入路径和TXT输出路径
            # 拼接CSV文件完整路径
            input_csv_full_path = os.path.join(csv_folder_path, file_name)
            # 替换文件后缀为.txt,保留原文件名
            txt_file_name = os.path.splitext(file_name)[0] + ".txt"
            # 拼接TXT文件完整路径
            output_txt_full_path = os.path.join(txt_folder_path, txt_file_name)

            # 4. 调用单个转换函数,处理当前CSV文件
            csv_to_txt_single(input_csv_full_path, output_txt_full_path)

    # 5. 批量转换完成提示
    print(f"\n批量转换任务结束!所有TXT文件已保存至:{txt_folder_path}")

# 调用批量转换函数执行任务
if __name__ == "__main__":
    # 配置输入CSV文件夹和输出TXT文件夹路径(可根据自己的需求修改)
    INPUT_CSV_FOLDER = "input_csvs"  # 存放所有待转换CSV的文件夹
    OUTPUT_TXT_FOLDER = "output_txts"  # 存放转换后TXT的文件夹

    # 执行批量转换
    csv_to_txt_batch(INPUT_CSV_FOLDER, OUTPUT_TXT_FOLDER)

代码关键解析:

  1. 文件夹处理 :使用 os.makedirs() 创建输出文件夹,避免因文件夹不存在导致写入失败;
  2. 文件筛选 :通过 file_name.lower().endswith(".csv") 筛选 CSV 文件,忽略文件名后缀的大小写差异,提升兼容性;
  3. 文件名保留 :使用 os.path.splitext() 分割原文件名和后缀,生成对应的 TXT 文件名,保持文件命名的一致性;
  4. 异常隔离:单个 CSV 文件转换失败不会影响其他文件的处理,提升批量任务的稳定性。

输出:


五、总结与拓展

本文通过免费 Python 库实现了 CSV 到 TXT 文本格式的单文件转换和批量转换,核心优势如下:

  1. 无需依赖 Excel 环境,跨平台兼容性强;
  2. 封装完善,无需手动解析 CSV 格式,降低开发成本;
  3. 支持编码自定义和数据格式化,解决实际场景中的常见问题。

拓展场景:

  1. 数据筛选后转换:在遍历工作表数据时,增加条件判断,实现精准数据转换;
  2. CSV 转带格式 TXT :通过格式化字符串(如{:10s})固定列宽,生成更规范的结构化 TXT 文件;
  3. 其他格式转换 :Free Spire.XLS for Python 还支持 CSV 转 ExcelExcel 转 TXT,可通过类似逻辑实现多格式互转。

通过本文的代码和指南,你可以快速实现高效的 CSV 转 TXT 处理,满足日常数据归档和传输的需求,同时也可基于该库拓展更多复杂的数据处理功能。

相关推荐
fengfuyao98511 小时前
基于C#实现的支持五笔和拼音输入的输入法
开发语言·c#
brent42311 小时前
DAY44 Dataset和Dataloader类
python·深度学习
ALex_zry11 小时前
CMake变量传递与宏定义技术详解:从问题到解决方案
开发语言·spring·cmake·条件编译
lang2015092811 小时前
彻底理解CountDownLatch
java·开发语言
Jelena1577958579211 小时前
实战解析:京东关键词搜索 item_search_pro —— 按关键字搜索商品
开发语言·数据库·python
2501_9418705611 小时前
从日志泛滥到结构化可观测体系落地的互联网系统工程实践随笔与多语言语法思考
开发语言·python
山沐与山11 小时前
【MQ】MQ消息队列幂等性设计与踩坑实战
java·开发语言·数据库·rocketmq
JAY_LIN——811 小时前
数据在内存中的存储
c语言·开发语言
小李子呢021111 小时前
Javascript学习(六)--Web APIs(日期对象,节点操作,M端事件,JS插件,综合案例)
开发语言·前端·javascript·学习
席万里11 小时前
1. 两数之和
python