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

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

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

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

Q&A

解決済

2回答

1097閲覧

VBA 連続貼付けで列が変わった時に、1行目から張り付ける

SSS_

総合スコア2

VBA

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

0グッド

0クリップ

投稿2020/10/13 07:03

編集2020/10/13 07:29

B列のe,f・・・・・を2行目から記入させたいです。

testフォルダに入っているAAAとBBBという二つのブックのH列に東京という文字が入っているものを抽出して別ブックに貼りつけるコードを作りました。
貼り付け先のブックでは、行を詰めたいです。
AAAで4列目まで貼付け、その後BBBに異動した際BBBも1行目から記載してほしいのですが5行目から記載されてしまいます。
どのような操作をすればBBBのデータも1列目から記載することができるでしょうか。

【現状】
AAAのデータ  BBBのデータ
1 a
2 b
3 c
4 d
5         e
6         f

【やりたいこと】
AAAのデータ  BBBのデータ
1 a       e
2 b      f
3 c
4 d
5     
6   

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

エラーメッセージ

該当のソースコード

Sub fileopenexport() Dim testSheet As Worksheet Set testSheet = ThisWorkbook.Worksheets(1) Const Path As String = "C:\Users\Desktop\test\" Dim buf As String buf = Dir(Path & "*.xlsm") Dim i As Long Do While buf <> "" i = i + 1 Dim Book As Workbook Set Book = Workbooks.Open(Path + buf) Dim ws1 As Worksheet, ws2 As Worksheet Dim all_row As Long Dim j As Long, q As Long Set ws1 = Book.Sheets(1) Set ws2 = Book.Sheets(2) all_row = ws1.Cells(ws1.Rows.Count, 1).End(xlUp).row For q = 2 To all_row If ws1.Cells(q, 8).Value Like "*東京*" Then j = j + 1 testSheet.Cells(j , i) = ws1.Cells(q, 1).Value End If Next Book.Close False buf = Dir() Loop End Sub

試したこと

ここに問題に対して試したことを記載してください。

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

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

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

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

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

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

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

meg_

2020/10/13 07:26

確認ですが、 > その後BBBに異動した際BBBも1行目から記載してほしいのですが5列目から記載されてしまいます。 列ですか?行ですか?
SSS_

2020/10/13 07:29

申し訳ございません 誤字を訂正しました 5列→5行でした
guest

回答2

0

これも一つの方法

vba

1Sub tes() 2Dim n, q, all_row 3Dim tesRow, tesCol 4 5Dim testSheet As Worksheet 6Set testSheet = ThisWorkbook.Worksheets(1) 7 8all_row = 20 9For n = 0 To all_row - 2 10 tesRow = (n Mod 4) + 1 11 tesCol = Int(n / 4) + 1 12 q = n + 2 13 testSheet.Cells(tesRow, tesCol).Value = q & "行" 14Next 15End Sub

投稿2020/10/13 08:00

sinzo

総合スコア10

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

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

SSS_

2020/10/13 08:15

ご回答ありがとうございます。 余りを利用した条件分けは苦手なので克服できるように勉強いたします。 ありがとうございました!
guest

0

ベストアンサー

Long型の変数を定義されていない状態で定義すると0の値で初期化されますが、
既に変数が定義されている場合は何も起きません。

列が切り替わった時に値が増えていってしまうのは、
jを初期化にまかせて値を明示的に設定していないからです。

検索しているFor文の外側で明示的に0を設定すれば、
列が変わる毎に上から書き出してくれると思います。

VBA

1 j = 0 2 For q = 2 To all_row

投稿2020/10/13 07:30

編集2020/10/13 07:33
yureighost

総合スコア2183

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

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

SSS_

2020/10/13 08:14

誠にありがとうございます。 ループの外でjをリセットするのですね。 無事にできました。 ありがとうございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問