Python的Excel处理 一:事项txt格式到Excel格式的转换,并提取Excel中指定关键字所在的所有行数据

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表格的进一步处理(细化)

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

  • 1
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Jackson的生态模型

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值