1. txt格式到Excel格式转换
1. 文件展示:
2. txt文件内容:
import os
import pandas as pd
filePath = r'E:\wenjian\practice'
filenames = [file for file in os.walk(filePath)]
ds = []
lis = []
for each in filenames[0][-1]:
with open(filenames[0][0]+'\\'+each,mode='r',encoding='utf-8')as f:
data = f.readlines()
datas = [each.split() for each in data]
ds.append(datas)
[lis.extend(i) for i in ds]
df = pd.DataFrame(lis)
df = df.drop_duplicates()
df.to_excel('translate.xlsx',header=False, index=False)
合并效果:
2.提取Excel中指定关键字所在的所有行数据
import xlrd2
import xlwt
def read_excel():
workbook = xlrd2.open_workbook('F:\\new5.xls') #读取源excel文件,最好利用绝对路径(完整路径,从哪个盘开始)
jieguo = xlwt.Workbook(encoding="ascii") #生成excel
wsheet = jieguo.add_sheet('sheet name') #生成sheet
sheetnum=workbook.nsheets #获取源文件sheet数目
y=0 #生成的excel的行计数
for m in range(0,sheetnum):
sheet = workbook.sheet_by_index(m) #读取源excel文件第m个sheet的内容
nrowsnum=sheet.nrows #获取该sheet的行数
for i in range(0,nrowsnum):
date=sheet.row(i) #获取该sheet第i行的内容
for n in range(0,len(date)):
aaa=str(date[n]) #把该行第n个单元格转化为字符串,目的是下一步的关键字比对
if aaa.find('keyword')>0: #进行关键字比对,包含关键字返回1,否则返回0
y=y+1
for j in range(len(date)):
wsheet.write(y,j,sheet.cell_value(i,j)) #该行包含关键字,则把它所有单元格依次写入入新生成的excel的第y行
jieguo.save('F:\\new5Result.xls') #保存新生成的Excel
if __name__ == '__main__':
read_excel()
结果展示:
可能会出现的问题:AttributeError: ‘ElementTree’ object has no attribute ‘getiterator’
解决办法: 在wind中找出目录python\Lib\site-packages\xlrd2下的xlsx.py文件,修改两个地方的的getiterator()改成iter(),下面的两个地方,这里已经把getiterator()改成了iter()。
3. Excel表格的进一步处理(细化)