在python中利用xlrd/xlwt对excel进行关键字查找并生成新表

xlrd对exce进行读操作,xlwt对exce进行写操作。实现把excel中某些单元格部分字符作为关键字,进行查找。话不多说直接上代码。

# -*- coding: utf-8 -*-
import xlrd
import xlwt


def read_excel():
	workbook = xlrd.open_workbook('tttttt.xlsx') #读取源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('关键字')>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



if __name__ == '__main__':
    read_excel()

因为关键字判断是针对单元格的,所以,如果一行数据中有多个关键字,结果也会生成多行。

posted @ 2019-03-22 09:18  宫爆鸡丁丁  阅读(8617)  评论(0编辑  收藏  举报