在数据处理、报表归档和跨平台数据传输场景中,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. 注意事项
- 支持python 3.6及以上版本;
- 免费版对单个文件的处理行数有一定限制(满足常规小型数据处理需求);
- 安装完成后,直接导入
spire.xls即可使用核心功能。
二、csv 转 txt 文本文件的核心逻辑
使用 free spire.xls for python 实现 csv 转 txt 的核心流程清晰易懂,无需复杂的解析逻辑,库已封装好 csv 文件的读取接口,核心步骤如下:
- 创建
workbook对象(工作簿),用于承载 csv 文件数据; - 调用
workbook.loadfromfile()方法加载目标 csv 文件,指定正确编码避免中文乱码; - 获取 csv 文件对应的工作表(
worksheet),csv 加载后默认生成单个工作表; - 调用
worksheet.savetofile()方法将 csv 另存为 txt 文本格式,自定义数据分隔格式及编码; - 释放资源,完成转换。
三、案例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)
代码关键解析:
- 文件夹处理:使用
os.makedirs()创建输出文件夹,避免因文件夹不存在导致写入失败; - 文件筛选:通过
file_name.lower().endswith(".csv")筛选 csv 文件,忽略文件名后缀的大小写差异,提升兼容性; - 文件名保留:使用
os.path.splitext()分割原文件名和后缀,生成对应的 txt 文件名,保持文件命名的一致性; - 异常隔离:单个 csv 文件转换失败不会影响其他文件的处理,提升批量任务的稳定性。
输出:

五、总结与拓展
本文通过免费 python 库实现了 csv 到 txt 文本格式的单文件转换和批量转换,核心优势如下:
- 无需依赖 excel 环境,跨平台兼容性强;
- 封装完善,无需手动解析 csv 格式,降低开发成本;
- 支持编码自定义和数据格式化,解决实际场景中的常见问题。
拓展场景:
- 数据筛选后转换:在遍历工作表数据时,增加条件判断,实现精准数据转换;
- csv 转带格式 txt:通过格式化字符串(如
{:10s})固定列宽,生成更规范的结构化 txt 文件; - 其他格式转换:free spire.xls for python 还支持 csv 转 excel、excel 转 txt,可通过类似逻辑实现多格式互转。
通过本文的代码和指南,你可以快速实现高效的 csv 转 txt 处理,满足日常数据归档和传输的需求,同时也可基于该库拓展更多复杂的数据处理功能。
到此这篇关于python实现csv转txt格式(单文件+批量处理)的文章就介绍到这了,更多相关python csv转txt内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!
发表评论