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

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

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

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

マクロ

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

Q&A

解決済

3回答

21409閲覧

【VBA】列をずらしてコピー(形式選択あり)

freu

総合スコア7

VBA

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

マクロ

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

0グッド

0クリップ

投稿2016/08/25 11:02

VBA勉強中です。

sheet1のB列をコピー→sheet2のC列へコピー
sheet1のC列をコピー→sheet2のF列へコピー
sheet1のD列をコピー→sheet2のI列へコピー
・・・繰り返し

をマクロでさせたくて

Sub コピー()
Dim i, j

Worksheets("sheet1").Activate
For i = 2 To 20
For j = 3 To 40 Step 2
Worksheets("sheet1").Range(Columns(i)).Copy Worksheets("sheet2").Range("j")
Next i
Next j

End Sub

と書いてみたのですが、上手く行きません。
修正もしくは正しいコードを教えて貰えればと思っています。

上記のコードはいくつかのマクロの一部で、

ピボットテーブルからデータを抽出し別シートにコピー

VBAで列を挿入

別のデータ一覧から同じ名前がある列の値を元のデータの隣の列にコピー(ここを上記のコードで行いたい)

2つの列の値を計算して割合を算出

余り複雑なコードは組めないので、分割してやってます。
ピボットテーブルはデータの抽出内容でいろいろ変わるので、
本来であれば、複数条件で抽出したデータをコピー出来るようなマクロを組めればいいのですが、
まだそこまでは出来そうに有りません。

アドバイス貰えれば助かります。
よろしくお願いいたします。

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

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

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

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

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

guest

回答3

0

ベストアンサー

それぞれのループの意味を考えてみましょう。
iループは読み取り列のループですよね。
そしてjループには出力列のループを期待しているのでしょう。

しかし、今回の動作では読み取った1列に対して何列も繰り返し出力をする必要はありません。
B列を読んだら、C列に出力する。
C列を読んだら、F列に出力する。
というように、常に1対1の出力です。

つまり、ループはひとつで充分ということです。

以下サンプルコードです。

Dim shtRead As Worksheet Dim shtWrite As Worksheet Set shtRead = Worksheets("Sheet1") Set shtWrite = Worksheets("Sheet2") Dim i As Integer Dim iColRead As Integer Dim iColWrite As Integer iColRead = 1 '読込初期値はB列 iColWrite = 3 '出力初期値はC列 For i = 1 to 19 '列をコピー shtRead.Columns(iColRead).Copy shtWrite.Columns(iColWrite) '次回の読込列 iColRead = iColRead + 1 '次回の出力列 iColWrite = iColWrite + 3 '今回は以下のようにiからの計算でもできます 'iColRead = i + 1 'iColWrite = i * 3 'shtRead.Columns(iColRead).Copy shtWrite.Columns(iColWrite) Next

投稿2016/08/26 03:10

編集2016/08/26 03:11
jawa

総合スコア3013

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

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

freu

2016/08/26 05:10

ループの説明からして頂き、ありがとうございます。 自分がループを曖昧に理解していることに気づかせていただきました。 頂いたコードも非常にわかりやすく、今後に活かせていけると思います。 回答頂き、ありがとうございました。
guest

0

細かくは見ていませんが、
後ろのnext iとnext jが、
逆です。

まずはこれを修正されては
いかがでしょうか?

投稿2016/08/25 11:11

Yatsurugi

総合スコア1628

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

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

freu

2016/08/26 04:55

早速のコメントありがとうございます。 逆にしてみたのですが、解決せず。。。 理解力不足で申し訳ありません。
guest

0

こういうことでしょうか?

VBA

1 Sub コピー() 2 Dim i, j 3 4 Worksheets("sheet1").Activate 5 j = 1 6 For i = 2 To 20 7 Worksheets("sheet1").Columns(i).Copy (Worksheets("sheet2").Columns(i + j)) 8 j = j + 2 9 Next i 10 11End Sub 12

投稿2016/08/26 02:53

SASAHARA

総合スコア247

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

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

freu

2016/08/26 05:02

なるほど。。。 ただ、これだとiの開始列指定は出来ますが、 jがiに同期しているので、jの開始列指定は出来なくなってしまいますね。 問題なく作動はしましたので、参考にさせて頂きます。 回答ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問