知行编程网知行编程网  2022-09-06 00:00 知行编程网 隐藏边栏  96 
文章评分 0 次,平均分 0.0
导语: 本文主要介绍了关于Python如何实现excel筛选后生成新表的相关知识,包括excel筛选结果导出,以及如何导出excel筛选内容这些编程知识,希望对大家有参考作用。

如何在Python中进行excel过滤后生成新表


Python如何实现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()

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

本文为原创文章,版权归所有,欢迎分享本文,转载请保留出处!

知行编程网
知行编程网 关注:1    粉丝:1
这个人很懒,什么都没写
扫一扫二维码分享