百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

Python如何读取excel文件内容并进行相应处理(Python excel读取)

off999 2024-10-07 12:08 19 浏览 0 评论

from openpyxl import load_workbook
path = r'D:\pythondata\result'
workbook = load_workbook(path +'/'+ 'excel_test.xlsx')
#print(workbook.sheetnames) #显示总共有几个工作表

#只有一个表时
#sheet = workbook['Sheet1']
#sheet = workbook.active
sheet = workbook['Class 1']
#print(sheet.dimensions)  # 获取的表格的范围:A1:C4
cell = sheet['B1']  #显示B1单元格的内容
#print(cell.value) # 获取B1表格的数据,结果:ID

col_content = sheet['B']  # 表示获取B这一列
row_content = sheet[3]  #获取第3行数据
#for row in row_content:  #显示第三行的所有内容
    #print(row.value)

def get_row_value():#逐行获取内容
    for row in sheet.iter_rows(min_row=2, max_row=4, min_col= 1,max_col=3):  #显示 2-4行,1-3列的内容 
        # print(row) # 每行的内容是一个元组的内容,如果想看到数据还需要继续遍历
        for cell in row:
            print(cell.value)

def get_col_value():#逐列获取内容
    for col in sheet.iter_cols(min_row=2, max_row=4, min_col= 1,max_col=3): #逐列获取内容
        #print(col)
        for cell in col:
            print(cell.value)

def get_empty_cell(): #找出空单元格
    from openpyxl import load_workbook

    path = r'D:\pythondata\result'
    workbook = load_workbook(path +'/'+ 'excel_test.xlsx')
    #print(workbook.sheetnames) #显示总共有几个工作表

    #只有一个表时
    #sheet = workbook['Sheet1']
    #sheet = workbook.active
    sheet = workbook['Class 1']
    # 获取工作簿的范围并切割 范围:'A1:K1473' ---->使用字符串的split分隔得到:['A1','K1473']
    size_ls=sheet.dimensions.split(':')
    # 从而可以得到行和列的最大和最小值
    col_min,row_min,col_max,row_max = size_ls[0][0],size_ls[0][1],size_ls[1][0],size_ls[1][1:]
    # print(col_min,row_min,col_max,row_max)  # 打印结果是:A,1,K,1473   即最小列是A,最大列是K,最小行是1,最大行是1473

    # 声明一个空的列表存放有空值的单元格坐标
    none_list = []
    # 遍历行和列
    # 遍历列,但是需要注意的是列是字母,所以要使用ord将字母转成数字才可以使用range范围
    for col in range(ord(col_min),ord(col_max)+1):  
        # 遍历行,将字符串的行转成整型
        for row in range(int(row_min), int(row_max)+1):
        # 通过chr(col)+str(row)获取单元格坐标,再通过chr将数字转成字母比如65就是A,所以chr(col)+str(row)的结果类似是:A3
            if sheet[chr(col)+str(row)].value == None:
            # 如果某个单元格没有值则将单元格坐标保存到列表:none_list中
                none_list.append(chr(col)+str(row))
    # 打印查看none_list里面的内容
    for i in none_list:
        print(i)

def get_specific_column(): #对某一列进行相应处理
#找出C列数值大于3200的所有单元格
    cells = sheet['C']
    data_list = []
    for cell in cells:
        if isinstance(cell.value,int) and cell.value >3200:  #如果单元里的数值>3200
            data_list.append(cell.row)
    print('输出满足条件的数据所在行数的列表:\n{}\n'.format(data_list))

def get_specific_row(): #对某一行进行相应处理
#找出第三行内容为Female的所有单元格
    cells = sheet[3]  #第三行
    data_list = []
    for cell in cells:
        if cell.value == 'Female':    #如果单元格的内容为 Female
            data_list.append(cell.row)
    print('输出满足条件的数据所在列数的列表:\n{}\n'.format(data_list))

说明:先要安装openpyxl模块(专门处理excel文件的模块),方法:在visual studio code下方 >后 输入: pip install openpyxl,直到出现successfully installed,再运行上述代码

相关推荐

使用 python-fire 快速构建 CLI_如何搭建python项目架构

命令行应用程序是开发人员最好的朋友。想快速完成某事?只需敲击几下键盘,您就已经拥有了想要的东西。Python是许多开发人员在需要快速组合某些东西时选择的第一语言。但是我们拼凑起来的东西在大多数时候并...

Python 闭包:从底层逻辑到实战避坑,附安全防护指南

一、闭包到底是什么?你可以把闭包理解成一个"带记忆的函数"。它诞生时会悄悄记下自己周围的变量,哪怕跑到别的地方执行,这些"记忆"也不会丢失。就像有人出门时总会带上...

使用Python实现九九乘法表的打印_用python打印一个九九乘法表

任务要求九九乘法表的结构如下:1×1=11×2=22×2=41×3=32×3=63×3=9...1×9=92×9=18...9×9=81使用Python编写程序,按照上述格式打印出完整的九...

吊打面试官(四)--Java语法基础运算符一文全掌握

简介本文介绍了Java运算符相关知识,包含运算规则,运算符使用经验,特殊运算符注意事项等,全文5400字。熟悉了这些内容,在运算符这块就可以吊打面试官了。Java运算符的规则与特性1.贪心规则(Ma...

Python三目运算基础与进阶_python三目运算符判断三个变量

#头条创作挑战赛#Python中你学会了三步运算,你将会省去很多无用的代码,我接下来由基础到进阶的方式讲解Python三目运算基础在Python中,三目运算符也称为条件表达式。它可以通过一行代码实现条...

Python 中 必须掌握的 20 个核心函数——set()详解

set()是Python中用于创建集合的核心函数,集合是一种无序、不重复元素的容器,非常适合用于成员检测、去重和数学集合运算。一、set()的基本用法1.1创建空集合#创建空集合empty_se...

15个让Python编码效率翻倍的实用技巧

在软件开发领域,代码质量往往比代码数量更重要。本文整理的15个Python编码技巧,源自开发者在真实项目中验证过的工作方法,能够帮助您用更简洁的代码实现更清晰的逻辑。这些技巧覆盖基础语法优化到高级特性...

《Python从小白到入门》自学课程目录汇总(和猫妹学Python)

小朋友们好,大朋友们好!不知不觉,这套猫妹自学Python基础课程已经结束了,猫妹体会到了水滴石穿的力量。水一直向下滴,时间长了能把石头滴穿。只要坚持不懈,细微之力也能做出很难办的事。就比如咱们的学习...

8÷2(2+2) 等于1还是16?国外网友为这道小学数学题吵疯了……

近日,国外网友因为一道小学数学题在推特上争得热火朝天。事情的起因是一个推特网友@pjmdoll发布了一条推文,让他的关注者解答一道数学题:Viralmathequationshavebeen...

Python学不会来打我(21)python表达式知识点汇总

在Python中,表达式是由变量、运算符、函数调用等组合而成的语句,用于产生值或执行特定操作。以下是对Python中常见表达式的详细讲解:1.1算术表达式涉及数学运算的表达式。例如:a=5b...

Python运算符:数学助手,轻松拿咧

Python中的运算符就像是生活中的数学助手,帮助我们快速准确地完成这些计算。比如购物时计算总价、做家务时分配任务等。这篇文章就来详细聊聊Python中的各种运算符,并通过实际代码示例帮助你更好地理解...

Python学不会来打我(17)逻辑运算符的使用方法与使用场景

在Python编程中,逻辑运算符(LogicalOperators)是用于组合多个条件表达式的关键工具。它们可以将多个布尔表达式连接起来,形成更复杂的判断逻辑,并返回一个布尔值(True或Fa...

Python编程基础:运算符的优先级_python中的运算符优先级问题

多个运算符同时出现在一个表达式中时,先执行哪个,后执行哪个,这就涉及运算符的优先级。如数学表达式,有+、-、×、÷、()等,优先级顺序是()、×、÷、+、-,如5+(5-3)×4÷2,先计算(5-3)...

Python运算符与表达式_python中运算符&的功能

一、运算符分类总览1.Python运算符全景图2.运算符优先级表表1.3.1Python运算符优先级(从高到低)优先级运算符描述结合性1**指数右→左2~+-位非/一元加减右→左3*//...

Python操作Excel:从基础到高级的深度实践

Python凭借其丰富的库生态系统,已成为自动化处理Excel数据的强大工具。本文将深入探讨五个关键领域,通过实际代码示例展示如何利用Python进行高效的Excel操作,涵盖数据处理、格式控制、可视...

取消回复欢迎 发表评论: