将多个txt文件转换为一个excel文件,xlwt包的基本使用(包含代码)代码都有注解,保姆级别教程。

本文主要是介绍将多个txt文件转换为一个excel文件,xlwt包的基本使用(包含代码)代码都有注解,保姆级别教程。,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、首先了解一下xlwt包的一些基本方法和使用:

ps:(如果明白xlwt包基础使用的同学可以直接看第二部分,多个txt输入到一个excel文件当中去。)

Python中使用的是xlwt模块来生成Excel文件,并且可以控制单元格的格式。xlwt.Workbook()返回的xlwt.Workbook类型的save(filepath)方法可以保存excel文件。下面就让我们看看写excel文件的流程及需要使用的函数吧。写excel前也必须先导入该模块(import xlwt)。

基本流程如下:

1.1 安装xlwt包:

打开pycharm,在terminal终端上输入pip install xlwt就行。另外还有个可能要用到的os包也同样可以在这里导入pip install os

1.2 创建表格和工作表单(sheet)

用workbook的add_sheet方法添加表单,可以添加多个表单,也就是对应图二下面excel表的sheet

import os
import xlwtworkbook = xlwt.Workbook()  # 创建一个Workbook对象
worksheet = workbook.add_sheet('sheet')  # 由workbook对象生成一个叫命名为sheet1的表单(sheet)

 

 1.3 接下来就可以在excel表单的单元格中添加数据:

使用worksheet的write方法写入,对应参数如:worksheet.write(row,col,value)行,列,值(行列下标都是从0开始)。例如我在表单(0,0)中添加内容:并且保存excel文件为shuaige.xsl

import os
import xlwtworkbook = xlwt.Workbook()  # 创建一个Workbook对象
worksheet = workbook.add_sheet('sheet1')  # 由workbook对象生成一个叫命名为vi的表单(sheet)worksheet.write(0, 0, '我是一个大帅逼')
workbook.save('shuaige.xls')

接着项目中就会出现这个文档:

 打开看看

 好了这就是xlwt包的基础使用,接下来我们用它来完成多个txt文件转到一个excel文件当中去。

二、多个txt文件输入到一个excel文件中去:

我们有一个文件夹有这么多txt文件,并且每个文件中还有两个不同种的语言,想要将其分开并且得到一个excel表。如图:

txt文件是这样的:一行越南语,一行中文。 

我们想要得到的样子:(这里我已经编程实现了所以才有结果图,不然我还处理干啥是吧😀)

一个表单页面的第一列,顺序下去的每一行放一个txt文件的越南语,对应一页放对应的中文翻译。

 -------------------------------------------------------------------------------------------------------------------------分割

 

 好,让我们看怎么实现:

我直接放代码,然后再一步一步解析:

import xlwt
import os# 一个txt文件转excel文件的封装对象
class TxtToExcel(object):def __init__(self, path):self.path = path  # txt文件路径self.workbook = xlwt.Workbook(encoding='UTF-8')  # 创建工作表''' add_sheet(sheet_name): 添加sheetget_sheet(Sheet_name): 选择sheetsave(file_name): 保存'''self.worksheet1 = self.workbook.add_sheet('vi', cell_overwrite_ok=True)  # 工作表里面添加一个sheet表self.worksheet2 = self.workbook.add_sheet('chi', cell_overwrite_ok=True)# 读取txt文件内容def read_content(self, file):with open(self.path + r'\\' + file, 'r', encoding='utf-8') as f:print('读取txt内容')return f.readlines()  # 将读取到的 行s 返回出  返回的是一个list 带有\n# 文件列表def file_list(self):print('返回文件list')return os.listdir(self.path)  # 返回一个list,是当前文档里面所有文件的名称def write_to_excel_sheet1(self, row, param, c):print('写入sheet1')self.worksheet1 = self.workbook.get_sheet('vi')self.worksheet1.write(row, param, c)def write_to_excel_sheet2(self, row, param, c):print('写入sheet2')self.worksheet2 = self.workbook.get_sheet('chi')self.worksheet2.write(row, param, c)# 得到文件列表def get_file_path_list(self):print('运行get_file')file_path_list = self.file_list()print(file_path_list)for j, file in enumerate(file_path_list):  # 遍历文档的文件# with open(self.path + r'\\' + file, 'r', encoding='utf-8') as f:#     content = f.readlines()content = self.read_content(file)print('读取内容', content)sheet1_content = ''  # 用于存储越南语sheet2_content = ''  # 用于存储汉语for i, c in enumerate(content):   # enumerate函数是将list分为下标和值对应,也就是i为对应下标遍历,c为i位置上的内容。if i % 2 == 0:sheet1_content += celse:sheet2_content += cself.write_to_excel_sheet1(j, 0, sheet1_content)self.write_to_excel_sheet2(j, 0, sheet2_content)self.workbook.save('test.xls')if __name__ == '__main__':path = r"F:\test"  # txt文件夹位置TxtToExcel(path).get_file_path_list()

先理顺逻辑,我们想要将txt文件输入到excel中去,步骤1.先要批量打开txt文件,步骤2.然后再创建一个excel表,输入到excel表当中去:

想实现步骤1得先获取到txt文件位置:用

def file_list(self):print('返回文件list')return os.listdir(self.path)  # 返回一个list,是当前文档里面所有文件的名称

得到所有文件名称,一个list[]。

再打开txt文件读取内容,读取内容的同时将想要的越南语和汉语分开:

def read_content(self, file):with open(self.path + r'\\' + file, 'r', encoding='utf-8') as f:print('读取txt内容')return f.readlines()  # 将读取到的 行s 返回出  返回的是一个list 带有\n

打开的同时分开越南语和汉语:

for j, file in enumerate(file_path_list):  # 遍历文档的文件# with open(self.path + r'\\' + file, 'r', encoding='utf-8') as f:#     content = f.readlines()content = self.read_content(file)print('读取内容', content)sheet1_content = ''sheet2_content = ''for i, c in enumerate(content):if i % 2 == 0:    # 奇数行为越南语 sheet1_content += celse:     # 偶数行为汉语sheet2_content += c

接下来步骤2:要将内容给输入到excel文件当中去 , 要先创建excel表单:

def __init__(self, path):self.path = path  # txt文件路径self.workbook = xlwt.Workbook(encoding='UTF-8')  # 创建工作表''' add_sheet(sheet_name): 添加sheetget_sheet(Sheet_name): 选择sheetsave(file_name): 保存'''self.worksheet1 = self.workbook.add_sheet('vi', cell_overwrite_ok=True)  # 工作表里面添加一个vi表self.worksheet2 = self.workbook.add_sheet('chi', cell_overwrite_ok=True) #工作表里添加一个chi表

 保存到表单的方法:

def write_to_excel_sheet1(self, row, param, c):print('写入sheet1')self.worksheet1 = self.workbook.get_sheet('vi')self.worksheet1.write(row, param, c)def write_to_excel_sheet2(self, row, param, c):print('写入sheet2')self.worksheet2 = self.workbook.get_sheet('chi')self.worksheet2.write(row, param, c)

然后再是将内容一行一行写入excel中去:

for j, file in enumerate(file_path_list):  # 遍历文档的文件# with open(self.path + r'\\' + file, 'r', encoding='utf-8') as f:#     content = f.readlines()content = self.read_content(file)print('读取内容', content)sheet1_content = ''sheet2_content = ''for i, c in enumerate(content):if i % 2 == 0:sheet1_content += celse:sheet2_content += cself.write_to_excel_sheet1(j, 0, sheet1_content)self.write_to_excel_sheet2(j, 0, sheet2_content)self.workbook.save('test.xls')

好了  代码就带你读到这,在main方法中将文件夹路径放进去就好:

if __name__ == '__main__':path = r"F:\test"TxtToExcel(path).get_file_path_list()

搬运请告知。

这篇关于将多个txt文件转换为一个excel文件,xlwt包的基本使用(包含代码)代码都有注解,保姆级别教程。的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/336797

相关文章

基于 HTML5 Canvas 实现图片旋转与下载功能(完整代码展示)

《基于HTML5Canvas实现图片旋转与下载功能(完整代码展示)》本文将深入剖析一段基于HTML5Canvas的代码,该代码实现了图片的旋转(90度和180度)以及旋转后图片的下载... 目录一、引言二、html 结构分析三、css 样式分析四、JavaScript 功能实现一、引言在 Web 开发中,

Spring @Scheduled注解及工作原理

《Spring@Scheduled注解及工作原理》Spring的@Scheduled注解用于标记定时任务,无需额外库,需配置@EnableScheduling,设置fixedRate、fixedDe... 目录1.@Scheduled注解定义2.配置 @Scheduled2.1 开启定时任务支持2.2 创建

SpringBoot中使用Flux实现流式返回的方法小结

《SpringBoot中使用Flux实现流式返回的方法小结》文章介绍流式返回(StreamingResponse)在SpringBoot中通过Flux实现,优势包括提升用户体验、降低内存消耗、支持长连... 目录背景流式返回的核心概念与优势1. 提升用户体验2. 降低内存消耗3. 支持长连接与实时通信在Sp

Python如何去除图片干扰代码示例

《Python如何去除图片干扰代码示例》图片降噪是一个广泛应用于图像处理的技术,可以提高图像质量和相关应用的效果,:本文主要介绍Python如何去除图片干扰的相关资料,文中通过代码介绍的非常详细,... 目录一、噪声去除1. 高斯噪声(像素值正态分布扰动)2. 椒盐噪声(随机黑白像素点)3. 复杂噪声(如伪

SQL BETWEEN 语句的基本用法详解

《SQLBETWEEN语句的基本用法详解》SQLBETWEEN语句是一个用于在SQL查询中指定查询条件的重要工具,它允许用户指定一个范围,用于筛选符合特定条件的记录,本文将详细介绍BETWEEN语... 目录概述BETWEEN 语句的基本用法BETWEEN 语句的示例示例 1:查询年龄在 20 到 30 岁

Java Spring ApplicationEvent 代码示例解析

《JavaSpringApplicationEvent代码示例解析》本文解析了Spring事件机制,涵盖核心概念(发布-订阅/观察者模式)、代码实现(事件定义、发布、监听)及高级应用(异步处理、... 目录一、Spring 事件机制核心概念1. 事件驱动架构模型2. 核心组件二、代码示例解析1. 事件定义

python使用库爬取m3u8文件的示例

《python使用库爬取m3u8文件的示例》本文主要介绍了python使用库爬取m3u8文件的示例,可以使用requests、m3u8、ffmpeg等库,实现获取、解析、下载视频片段并合并等步骤,具有... 目录一、准备工作二、获取m3u8文件内容三、解析m3u8文件四、下载视频片段五、合并视频片段六、错误

gitlab安装及邮箱配置和常用使用方式

《gitlab安装及邮箱配置和常用使用方式》:本文主要介绍gitlab安装及邮箱配置和常用使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1.安装GitLab2.配置GitLab邮件服务3.GitLab的账号注册邮箱验证及其分组4.gitlab分支和标签的

SpringBoot3应用中集成和使用Spring Retry的实践记录

《SpringBoot3应用中集成和使用SpringRetry的实践记录》SpringRetry为SpringBoot3提供重试机制,支持注解和编程式两种方式,可配置重试策略与监听器,适用于临时性故... 目录1. 简介2. 环境准备3. 使用方式3.1 注解方式 基础使用自定义重试策略失败恢复机制注意事项

nginx启动命令和默认配置文件的使用

《nginx启动命令和默认配置文件的使用》:本文主要介绍nginx启动命令和默认配置文件的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录常见命令nginx.conf配置文件location匹配规则图片服务器总结常见命令# 默认配置文件启动./nginx