Python实现提取Excel指定关键词的行数据
作者:用余生去守护 发布时间:2022-09-01 10:15:59
标签:Python,Excel,关键词,数据
一、需求描述
1.图片展示
从如图所示的数据中提取含有"python"、"ubuntu"关键词的所有行数据,其它的不提取:
备注: 关键词和数据行列数可自定义!!!
提取前:
提取后:
2.提取方法
代码如下(示例):
import xlrd
import xlwt
data = xlrd.open_workbook(r'shuju.xlsx')
rtable = data.sheets()[0]
wbook = xlwt.Workbook(encoding='utf-8',style_compression = 0)
wtable = wbook.add_sheet('sheet1',cell_overwrite_ok = True)
count = 0
keyword = ('python')
keyword1 = ('ubuntu') #可添加多个关键词
for i in range(0,40): #区域按数据包含的行数进行填写,过多会显示超出范围(out of range)
if rtable.cell(i,2).value == keyword or rtable.cell(i,3).value == keyword or rtable.cell(i,4).value == keyword or rtable.cell(i,5).value == keyword or rtable.cell(i,2).value == keyword1 or rtable.cell(i,3).value == keyword1 or rtable.cell(i,4).value == keyword1 or rtable.cell(i,5).value == keyword1:
for j in range(0,5):
wtable.write(i,j,rtable.row_values(i)[j])
count += 1
print (count)
wbook.save(r'medicaldata.xls')
缺点:需要手动删除空白,容易出现超出范围错误!!
二、python提取第二版
1.图片展示
提取前:
提取后:
2.提取方法
代码如下(示例):
import os
import xlwt
import xlrd
from openpyxl import load_workbook
##目的文件夹
dirpath=r'E:\py\python3.7\test\test89tiqu'
keyword='python'
##遍历函数
def files(dirpath, suffix=['.xls', 'xlsx']):
for root ,dirs ,files in os.walk(dirpath):
for name in files:
if name.split('.')[-1] in suffix:
yield os.path.join(root, name)
if __name__ == '__main__':
jieguo = xlwt.Workbook(encoding="ascii") #生成excel
wsheet = jieguo.add_sheet('sheet name') #生成sheet
y=0 #生成的excel的行计数
try:
file_list = files(dirpath)
for filename in file_list:
workbook = xlrd.open_workbook(filename) #读取源excel文件
print(filename)
sheetnum=workbook.nsheets #获取源文件sheet数目
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个单元格转化为字符串,目的是下一步的关键字比对
print(aaa)
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('jieguo.xls') #保存新生成的Excel
except Exception as e:
print(e)
jieguo.save('jieguo.xls') #保存新生成的Excel
来源:https://blog.csdn.net/qq_45365214/article/details/123323049
0
投稿
猜你喜欢
- 尽管XML还处在开发阶段,其标准正在由W3C组织制定,但是已经有许多公司表示全力支持XML,并开发了不少XML工具。Adobe公司的Fram
- http://validator.w3.org/#validate_by_upload 在线校验网址点浏览,上次找到自己做的页面
- 简介 函数式编程语言在学术领域已经存在相当长一段时间了,但是从历史上看,它们没有丰富的工具和库可供使用。随着 .NET 平台上的
- 1、从半年以前要“去中心化”开始,豆瓣作了不少大的调整,重要的是上线了很多的新功能。同城、日记、相册、音乐试听、等等。2、一个多月来,豆瓣上
- 本文实例为大家分享了python控制nao机器人身体动作的具体代码,供大家参考,具体内容如下今天读的代码,顺便写了出来,与文档的对比,差不多
- 导语因为疫情无奈只能在家宅了好多天,随手玩了下自己以前做的一些小游戏,说真的,有几个游戏做的是真的劣质,譬如 flappybird 真的让我
- 介绍分面是指事物的多维度属性。例如一本书包含主题、作者、年代等分面。而分面搜索是指通过事物的这些属性不断筛选、过滤搜索结果的方法。可以将分面
- 这篇文章主要介绍了微信小程序顶部导航栏可滑动并选中放大,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋
- 英文原文:http://www.smashingmagazine.com/2008/08/18/译文原文:http://blog.bingo
- 现在市场上的OA基本上可归结为两大阵营,即php阵营和java阵营。但对接触Oa不久的用户来说,看到的往往只是它们的表相,只是明显的价格差异
- 学习目的: 学习ADO.NET用法,并如何用DataRearder读取数据 今天练习数据库的最基本用法,如何打开数据库。首先在网站设置文件w
- argparse是python标准库里面用来处理命令行参数的库命令行参数分为位置参数和选项参数:位置参数就是程序根据该参数出现的位置来确定的
- 在服务器端asp程序可以接受html页面上的form传来的参数,那么它又如何实现IE地址参数判断呢?当地址栏没有参数"id"时
- Dreamweaver从出道以来,其简便易用而又功能强大的“行为”(Behavior)一直是大家所关注的热点之一。在Dreamweaver
- 上篇关于爬虫的文章,我们讲解了如何运用Python的requests及BeautifuiSoup模块来完成静态网页的爬取,总结过程,网页爬虫
- 问题:MySQL 5.0不能使用自动增加字段。具体原因:引起的原因是在MySQL5.0.2版本中的The Server SQL Mode 中
- PS笔刷,样式,形状、渐变、滤镜载入方式及使用:1、笔刷载入方式: 打开PS,编辑-->预设管理器-->载入-->然后点你
- 第一种方法: 代码如下:Minimsdn.com为您提供的代码: -- Turn ON [Display IO Info when exec
- MySQL低调宣布它将不再把MySQL企业版服务器作为一个tar包发布,而这距离这个公司宣布将MySQL分为免费版和付费版的时间还不到一年。
- javascript中要判断一个变量是否为array通常是比较困难的,因为var a = [];alert(t