python3 read excel_关于Python 解决Python3.9 pandas.read_excel(‘xxx.xlsx‘)报错的问题

在Python3.9中使用pandas的read_excel()读取Excel文件时遇到AttributeError,原因是xlrd不支持Python3.9的iter方法。解决方案包括更换默认引擎为openpyxl或手动修改xlrd源码将getiterator替换为iter。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题描述

使用pandas库的read_excel()方法读取外部excel文件报错, 截图如下

76d771bcb2f153439868f415c23d1af9.png

好像是缺少了什么方法的样子

问题分析

分析个啥, 水平有限, 直接面向stackoverflow编程

https://stackoverflow.com/questions/64264563/attributeerror-elementtree-object-has-no-attribute-getiterator-when-trying

我找到了下面的这几种说法

04e0713961192701708d6576b2b55520.png

6377f7bee5e3271256751ea82b97a924.png

根据国外大神的指点, 我得出了这些结论:

pandas库读取excel文件是需要安装xlrd模块的, 也就是它默认是引擎engine是xlrd(之前已经手动pip3安装过), 使用Anaconda会把这些模块都安装上, 可是我没用Anaconda, 而是直接pip3 install pandas, 导致了很多其他模块需要自己安装. 但是安装了xlrd并不能解决问题, 因为我用的Python3.9, xlrd还没有对py3.9做相应的更新, 内部的getiterator方法在py3.9版本已经被移除, 需要将其替换成iter方法.

解决问题

方法一, 替换引擎

既然默认引擎xlrd出问题, 那干脆就直接换个, 指定engine为openpyxl

8d235dd8a3277dfa1621335588b69926.png

方法二, 修改源码

将已废弃掉的getiterator方法替换为iter方法

找到xlrd包下的xlsx.py, 进行替换!

cbb9477e4592cb6ff727b7d71a9480d5.png

99645a3d4286d3afd49d52242eba6d32.png

到此这篇关于关于Python 解决Python3.9 pandas.read_excel(‘xxx.xlsx‘)报错的问题的文章就介绍到这了,更多相关Python3.9 pandas.read_excel内容请搜索云海天教程以前的文章或继续浏览下面的相关文章希望大家以后多多支持云海天教程!

原文链接:https://blog.csdn.net/pineapple_C/article/details/110057494

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值