Python抓取excel中关键字

在面对几k行甚至上万行的excel数据时,如果只需要找出我们所需的某几行数据,可利用此代码,在设置好excel的路径、excel文件名关键字之后,即可抓取所需数据并输出至新的excel中。

三个参数:

  1. 所读取的excel(绝对路径+文件名+后缀)
workbook = xlrd.open_workbook('shuju.xls')
  1. 关键字
 if aaa.find('关键字')>0:
  1. 结果保存
jieguo.save('结果.xls') #保存新生成的Excel

完整代码:

import xlrd
import xlwt


def read_excel():
    workbook = xlrd.open_workbook('shuju.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('关键字')>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('结果.xls') #保存新生成的Excel



if __name__ == '__main__':
    read_excel()

你可能感兴趣的:(Python实用案例,python,excel)