【Python】已解决报错AttributeError: ‘Worksheet‘ object has no attribute ‘get_highest_row‘ 的解决办法

【Python】已解决报错AttributeError: ‘Worksheet’ object has no attribute ‘get_highest_row’ 的解决办法

在这里插入图片描述

😎 作者介绍:我是程序员洲洲,一个热爱写作的非著名程序员。CSDN全栈优质领域创作者、华为云博客社区云享专家、阿里云博客社区专家博主。
🤓 同时欢迎大家关注其他专栏,我将分享Web前后端开发、人工智能、机器学习、深度学习从0到1系列文章。
🌼 同时洲洲已经建立了程序员技术交流群,如果您感兴趣,可以私信我加入社群,可以直接vx联系(文末有名片)v:bdizztt
🖥 随时欢迎您跟我沟通,一起交流,一起成长、进步!点此也可获得联系方式~

前言

今天写Python的时候,遇到了这个问题:

D:\>python test.py
test.py:5: DeprecationWarning: Call to deprecated function get_sheet_by_name (Use wb[sheetname]).
  sheet = wb.get_sheet_by_name('Sheet1')
Traceback (most recent call last):
  File "test.py", line 12, in <module>
    print(sheet.get_highest_row())
AttributeError: 'Worksheet' object has no attribute 'get_highest_row'
print(sheet.get_highest_row())
AttributeError: 'Worksheet' object has no attribute 'get_highest_row'

我们来简单看看源代码是什么样的。

import openpyxl
wb = openpyxl.load_workbook('example.xlsx')
sheet = wb.get_sheet_by_name('Sheet1')
print(sheet.get_highest_row())

很多地方都有写:获取最大行的方法是:get_highest_row(),获取最大列的方法是:get_highest_row()。

那该怎么处理这个问题呢?
在这里插入图片描述

一、问题分析

在使用Python进行Excel操作时,开发者可能会使用openpyxl或xlsxwriter等库来处理工作簿(Workbook)和工作表(Worksheet)。

然而,在尝试获取工作表中的最大行数时,可能会遇到AttributeError: ‘Worksheet’ object has no attribute 'get_highest_row’的错误。

这个错误表明尝试访问的方法或属性在Worksheet对象中不存在。

错误的属性或方法调用

开发者可能错误地认为Worksheet对象有一个名为get_highest_row的方法或属性。

错误示例:

from openpyxl import load_workbook

wb = load_workbook('example.xlsx')
ws = wb['Sheet1']
highest_row = ws.get_highest_row()  # 错误:不存在此方法

库的版本问题

如果使用的Excel操作库版本不支持某个方法或属性,也可能导致此错误。

混淆不同的库或方法

开发者可能从其他库或文档中看到了类似的方法,但在使用的库中并不存在。

二、解决方案

解决方案一:使用正确的方法获取最大行数

对于openpyxl库,可以使用max_row属性来获取工作表中的最大行数。

from openpyxl import load_workbook

wb = load_workbook('example.xlsx')
ws = wb['Sheet1']
highest_row = ws.max_row  # 正确使用max_row属性

解决方案二:检查库的版本

确保使用的库版本支持所需的功能。如果不支持,考虑升级库版本。

# 检查openpyxl的版本
import openpyxl
print(openpyxl.__version__)

# 如果版本过低,可以使用pip进行升级
# pip install --upgrade openpyxl

解决方案三:使用其他库或方法

如果openpyxl不满足需求,可以考虑使用其他库,如xlsxwriter或pandas。

# 使用pandas读取Excel并获取最大行数
import pandas as pd

df = pd.read_excel('example.xlsx')
highest_row = df.shape[0]  # pandas DataFrame的最大行数

解决方案四(推荐使用)

get_highest_row()和get_highest_column()在最新版的openpyxl模块中已经被删除了,取而代之的是max_row和max_column两个方法。

所以我们只需要把两个方法改掉即可!

注意事项

  • 在使用任何库之前,确保阅读官方文档,了解支持的方法和属性。
  • 检查并确保使用的库版本是最新的,以获得最佳的功能支持和安全更新。
  • 在尝试调用某个方法或属性之前,使用诸如dir()的函数或IDE的自动完成功能来验证其存在性。
  • 如果遇到库不支持的功能,考虑使用其他库或编写自定义函数来实现所需功能。

总结

📝Hello,各位看官老爷们好,我已经建立了CSDN技术交流群,如果你很感兴趣,可以私信我加入我的社群。

📝社群中不定时会有很多活动,例如每周都会包邮免费送一些技术书籍及精美礼品、学习资料分享、大厂面经分享、技术讨论谈等等。

📝社群方向很多,相关领域有Web全栈(前后端)、人工智能、机器学习、自媒体副业交流、前沿科技文章分享、论文精读等等。

📝不管你是多新手的小白,都欢迎你加入社群中讨论、聊天、分享,加速助力你成为下一个大佬!

📝想都是问题,做都是答案!行动起来吧!欢迎评论区or后台与我沟通交流,也欢迎您点击下方的链接直接加入到我的交流社群!~ 跳转链接社区~

在这里插入图片描述

  • 17
    点赞
  • 28
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序员洲洲

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值