一、首先了解一下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 xlwt
workbook = 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 xlwt
workbook = 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): 添加sheet
get_sheet(Sheet_name): 选择sheet
save(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 += c
else:
sheet2_content += c
self.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 += c else: # 偶数行为汉语 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): 添加sheet get_sheet(Sheet_name): 选择sheet save(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 += c else: sheet2_content += c self.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()
搬运请告知。