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

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

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

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

2回答

3201閲覧

for文の繰り返しについて

akubareto

総合スコア1

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2020/11/18 04:00

編集2020/11/18 04:17

前提・実現したいこと

Excelデータから必要な1行データ(14セル)を抜き取り、それを新しいシートに12行複製してペーストする処理を元データの最終行まで行いたいと考えています。複数行にしてペーストする処理まではできたのですが、それを最終行まで繰り返させる処理がどうしても実行されません。どうすればできるかアドバイス頂きたいです。

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

エラーメッセージ

該当のソースコード

python

1def act(a): #1行分の列部分を取得する関数 2 3 4 for i in range(1,14):#指定した14セル抜き取る 5 copy = ws.cell(row = a, column =i).value 6 copy_prg = ws.cell(row = a, column =33).value 7 copy_biko = ws.cell(row = a, column =34).value 8 9 for j in range(1,12):#抜き取った部分を12行複製する 10 ws2.cell(row = j,column = i,value = copy) #列形式の部分をすべて貼り付け 11 ws2.cell(row = j,column = 1,value = ws['K1'].value) #1列目にk1を入れる 12 ws2.cell(row = j,column = 14,value = copy_prg) #AG列を入れる 13 ws2.cell(row = j,column = 15,value = copy_biko) #AH列入れる(改行なし) 14 15#この下の処理が上手くいきません 16 17max=int(ws.max_row) #最終行数の算出(221行) 18for y in range(6,max,4): #6行目から最終行まで4行飛ばしながら実行(1-3行は空欄のため) 19 act(6)

試したこと

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

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

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

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

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

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

meg_

2020/11/18 04:21

> この下の処理が上手くいきません 「上手くいきません」とは具体的にはどうなるのでしょうか?
akubareto

2020/11/18 04:24

1行の指定した部分抜き出す→貼り付け先(ws2)で12行に複製しながら貼り付けるを 最終行まで繰り返させたいと考えています。
akubareto

2020/11/18 04:25

1行文しか貼り付け先に反映しない状態になっています。
guest

回答2

0

ベストアンサー

petermanさんの指摘にもありますが、この処理のact(6)は act(y)にすべきです。

python

1for y in range(6,max,4): #6行目から最終行まで4行飛ばしながら実行(1-3行は空欄のため) 2 act(6)

以下の処理は、貼り付けの処理ですが、行番号が固定になっています。

python

1 for j in range(1,12):#抜き取った部分を12行複製する 2 ws2.cell(row = j,column = i,value = copy) #列形式の部分をすべて貼り付け

これでは、常に1行目から11行目(12にならない)までに値を書き込んでしまいます。
元の1行目が、1~12であれば、元の2行目は13~24に書き込まなければなりませんので、range()の引数を元の行の値によって変えなければなりません。
元の行数は変数aに入っています。宛先の行数はそれを使って計算で求められます。

投稿2020/11/18 07:23

TakaiY

総合スコア13790

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

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

akubareto

2020/11/18 07:28

ご回答ありがとうございます。 貼り付けの処理の行番号の指摘について、宛先の行数の求め方をお手数お掛けしますがご教示頂けますでしょうか。 宜しくお願い致します。
TakaiY

2020/11/18 07:37

開始行は、1, 13, 25, 37 になるので、 aが1,2,3... であれば、 (a-1)*12+1 が開始行ですね。
akubareto

2020/11/19 08:58

ありがとうございました! 無事作動しました。
guest

0

act関数の中身はよくわかりませんが、for文の中で毎回act(6)を実行するからインクリメントされないのでは?引数がyを含まないので同じ処理を繰り返すと思います。

投稿2020/11/18 04:35

peterman

総合スコア26

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

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

akubareto

2020/11/18 07:26

ご回答ありがとうございます。 確かに引数が固定になってました・・・ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問