• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

关于Python中openpyxl使用iter_rows()的方法

python 搞java代码 3年前 (2022-05-21) 23次浏览 已收录 0个评论

之前已经对iter函数的用法有过讲解,记忆遗忘的小伙伴可以重新回顾一遍。今天就iter函数的拓展,讲讲openpyxl中导入iter_rows()的方法。


当我们使用以下代码:


<p style="line-height: 1.75em"><span>import openpyxl as op
ms = op.load_workbook('mtest.xlsx')

ws = ms.active

op.worksheet.Worksheet.iter_rows()<br></span></p>

www#gaodaima.com来源gaodai$ma#com搞$代*码网搞代码


然后会出现,此代码返回:


<p style="line-height: 1.75em"><span>type object 'Worksheet' has no attribute 'iter_rows'<br></span></p>


怎么会出现这种情况?

这说明,您需要在工作表的实例上调用iter_rows方法,例如:


<p style="line-height: 1.75em"><span>>>> for row in ws.iter_rows('A1:C2'):
...        for cell in row:
...            print cell<br></span></p>


要么


<p style="line-height: 1.75em"><span>>>> for row in ws.iter_rows(min_row=1, max_col=3, max_row=2):
...    for cell in row:
...        print(cell) <br></span></p>


正如您的错误消息所述,您在Worksheet类型上调用它,这将无效;它需要在一个对象上调用:


<p style="line-height: 1.75em"><span>op.worksheet.Worksheet.iter_rows()  # wrong<br></span></p>


对于旧版本的openpyxl,您可能需要确保在加载工作簿时启用迭代器 –对于更新版本,这不是必需的。

以下是一个完整的例子在Python REPL中测试过(使用openpyxl 1.8.3):


<p style="line-height: 1.75em"><span>>>> import openpyxl as op
>>> wb = op.load_workbook('/tmp/test.xlsx', use_iterators=True)
>>> ws = wb.active
>>> for row in ws.iter_rows():
...   for cell in row:
...     print cell
... 
RawCell(row=1, column='A', coordinate='A1', internal_value=1.0, data_type='n', style_id='0', number_format='general')
RawCell(row=1, column='B', coordinate='B1', internal_value=10.0, data_type='n', style_id='0', number_format='general')
...<br></span></p>


还没有学会的小伙伴不要着急,结合之前学习再重新看一遍今天的示例,Python基础知识回顾:iter函数。

来源:搞代码网:原文地址:https://www.gaodaima.com


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:关于Python中openpyxl使用iter_rows()的方法
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址