質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
openpyxl

openpyxlは、Excel2007以降のファイル(xlsx/xlsm/xltx/xltm)を読み書きするためのPythonライブラリです。

for

for文は、様々なプログラミング言語で使われている制御構造です。for文に定義している条件から外れるまで、for文内の命令文を繰り返し実行します。

Q&A

1回答

360閲覧

Openpyxlにおける多重ループについて

sanyou_610

総合スコア0

openpyxl

openpyxlは、Excel2007以降のファイル(xlsx/xlsm/xltx/xltm)を読み書きするためのPythonライブラリです。

for

for文は、様々なプログラミング言語で使われている制御構造です。for文に定義している条件から外れるまで、for文内の命令文を繰り返し実行します。

0グッド

0クリップ

投稿2021/05/29 11:16

前提・実現したいこと

Openpyxlでパラメータx,yを含む式をまず、xを変化させて計算して、その最大値をセルに入力ということを今度はyを変化させて繰り返し行って絶対値の最大を求める。
■■な機能を実装中に以下のエラーメッセージが発生しました。

発生している問題・エラーメッセージ

2変数i,jを与えて多重ループを用いてプログラムを書いたが、jを変えて計算した結果が全く反映されない。上書きされてしまう。
エラーメッセージ
特になし

該当のソースコード

Python
ソースコード
import openpyxl
XLSFILE = r”C:\Users\Name\PycharmProjects\xy\test.xlsx
wb = openpyxl.load_workbook(XLSFILE, data_only = True)
ws_template = wb[“Sheet1”]

for j in range(1,601):
for i in range(1, 2689):
ws_template.cell(row=i+1, column=1).value = “=(50*{}+4{})/{}”.format(i, j, j)
ws_template.cell(row=j, column=2).value = “=MAX(ABS(A1:A2689))”

試したこと

data_only = Trueになっていることを確かめたが、何度やってもエクセル上には式が表示されてしまった。

補足情報(FW/ツールのバージョンなど)

ここにより詳細な情報を記載してください。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

最後に元のエクセルファイルに書き込みましょう。

python

1wb.save(XLSFILE)

投稿2021/05/29 11:43

編集2021/05/29 11:46
ppaul

総合スコア24666

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問