python

关注公众号 jb51net

关闭
首页 > 脚本专栏 > python > Python CSV转TXT

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

作者:Eiceblue

CSV格式因结构简洁、易与表格软件兼容而被广泛使用,但TXT格式具有更强的通用性、更低的存储冗余,下面我们就来看看如何使用Python实现二者的转换吧

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

一、安装免费 Python 库

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

1. 核心安装命令

pip install Spire.Xls.Free

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

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

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

3. 注意事项

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

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

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

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

完整代码实现:

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模块遍历文件夹,批量调用单文件转换逻辑,提升处理效率。

完整代码实现:

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)

代码关键解析:

输出:

五、总结与拓展

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

拓展场景:

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

到此这篇关于Python实现CSV转TXT格式(单文件+批量处理)的文章就介绍到这了,更多相关Python CSV转TXT内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文