web-dev-qa-db-ja.com

Python openpyxlパッケージでiter_rows()を使用する方法は?

Excelファイルを使用するために、Python(Canopy)openpyxlパッケージを使用しています。このリンクにはこのチュートリアルがあります: [〜#〜] link [〜#〜]

_you can also use the openpyxl.worksheet.Worksheet.iter_rows() method:

>>> Tuple(ws.iter_rows('A1:C2'))
((<Cell Sheet1.A1>, <Cell Sheet1.B1>, <Cell Sheet1.C1>),
 (<Cell Sheet1.A2>, <Cell Sheet1.B2>, <Cell Sheet1.C2>))

>>> for row in ws.iter_rows('A1:C2'):
...        for cell in row:
...            print cell
<Cell Sheet1.A1>
<Cell Sheet1.B1>
<Cell Sheet1.C1>
<Cell Sheet1.A2>
<Cell Sheet1.B2>
<Cell Sheet1.C2>
_

Pythonでopenpyxl.worksheet.Worksheet.iter_rows()メソッドをインポートするにはどうすればよいですか?私はこのコードを使用しました:

_import openpyxl as op
ms = op.load_workbook('mtest.xlsx')

ws = ms.active

op.worksheet.Worksheet.iter_rows()
_

このコードは以下を返します。

_type object 'Worksheet' has no attribute 'iter_rows' 
_

何が問題ですか?

11
user2991243

tutorial に示すように、ワークシートのインスタンスでiter_rowsメソッドを呼び出す必要があります。次に例を示します。

>>> for row in ws.iter_rows('A1:C2'):
...        for cell in row:
...            print cell

または

>>> for row in ws.iter_rows(min_row=1, max_col=3, max_row=2):
...    for cell in row:
...        print(cell)
<Cell Sheet1.A1>
<Cell Sheet1.B1>
<Cell Sheet1.C1>
<Cell Sheet1.A2>
<Cell Sheet1.B2>
<Cell Sheet1.C2>

エラーメッセージが示すように、Worksheettypeで呼び出していますが、機能しません。 オブジェクトで呼び出す必要があります

op.worksheet.Worksheet.iter_rows()  # wrong

別の回答の この例 も参照してください。

古いバージョンのopenpyxlの場合、ワークブックの読み込み時にイテレータを有効にする必要があります- this thread を参照してください。これは、より新しいバージョンでは必要ありません。

Python REPL(openpyxl 1.8.3))でテストしたばかりの完全な例を示します。

>>> 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')
...
15
DNA