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

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

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

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

マクロ

定義された処理手続きに応じて、どのような一連の処理を行うのかを特定させるルールをマクロと呼びます。

Q&A

解決済

1回答

1949閲覧

【VBA】セル範囲を下へ下へ間隔をあけてコピーしていきたい。

yoshicue

総合スコア8

VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

マクロ

定義された処理手続きに応じて、どのような一連の処理を行うのかを特定させるルールをマクロと呼びます。

0グッド

1クリップ

投稿2021/08/25 00:07

前提・実現したいこと

セル範囲をコピーして縦にペーストしてから
間隔をあけてまたセル範囲をコピーして、ペーストした直下からまたペースとして。
の繰り返し処理です。

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

ペーストそれ自体は下に処理できていくのですが、
コピー元がスタートのセル範囲から下がっていかないです。

該当のソースコード

Dim p As Integer

Dim q As Integer

For p = 13 To 710 Step 5

Range(Cells(p, 1), Cells(p, 4)).Select Application.CutCopyMode = False Selection.Copy For q = 11 To 147 Step 4 If Cells(q, 5).Value = "" Then Cells(q, 5).Select Selection.PasteSpecial Paste:=xlPasteAll, Operation:=xlNone, SkipBlanks:= _ False, Transpose:=True ElseIf Cells(q, 5).Value <> "" Then Exit For End If Next q

Next p

試したこと

For Next構文、Do While構文など。

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

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

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

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

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

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

guest

回答1

0

ベストアンサー

やりたいことがイマイチ把握できてないですが、こうですか?

VBA

1 Dim p As Integer 2 Dim q As Integer 3 q = 11 4 5 For p = 13 To 710 Step 5 6 Range(Cells(p, 1), Cells(p, 4)).Copy 7 If Cells(q, 5).Value = "" Then 8 Cells(q, 5).PasteSpecial Paste:=xlPasteAll, Operation:=xlNone, SkipBlanks:=False, Transpose:=True 9 q = q + 4 10 End If 11 Next p 12

投稿2021/08/25 03:00

jinoji

総合スコア4585

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

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

yoshicue

2021/08/25 04:37

For文に関してまだまだ至らない点がありましてこの度はたいへん助かりました。 意図をくみ取っていただきありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問