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

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

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

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

コピー

元のオブジェクトを破壊することなく、オブジェクトの複製を生成することをコピーと呼びます。

Q&A

解決済

2回答

846閲覧

複数ブックからシートをコピー

pomiw0000

総合スコア19

VBA

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

コピー

元のオブジェクトを破壊することなく、オブジェクトの複製を生成することをコピーと呼びます。

0グッド

0クリップ

投稿2021/09/09 03:11

前提・実現したいこと

複数ブックからシートをコピーしたいです。

3つのブックからシートを元ブックにコピーしてくる場合
For文を使うのはわかるのですが、どう書けばいいのかわからないので
教えていただきたいです。

今はブック名のところを編集して同じコードを3つ書いています。

該当のソースコード

VBA

1Sub test1() 2 3 4 ' ブック("Book1.xlsx)のシート(“Sheet1”)をアクティブ 5 Workbooks("Book1.xlsx").Worksheets("Sheet1").Activate 6 ' アクティブなシートをコピーして、ブック("Test.xlsm")の1番目のシートの後に挿入 7 ActiveSheet.Copy after:=Workbooks("Test.xlsm").Sheets(1) 8 9 WIth ActiveSheet.UsedRange 10 .Value = .Value 11 End With 12 13End Sub 14 15Sub test2() 16 17 18 ' ブック("Boo2.xlsx)のシート(“Sheet1”)をアクティブ 19 Workbooks("Book2.xlsx").Worksheets("Sheet1").Activate 20 ' アクティブなシートをコピーして、ブック("Test.xlsm")の1番目のシートの後に挿入 21 ActiveSheet.Copy after:=Workbooks("Test.xlsm").Sheets(1) 22 23 WIth ActiveSheet.UsedRange 24 .Value = .Value 25 End With 26 27End Sub 28 29Sub test3() 30 31 32 ' ブック("Book3.xlsx)のシート(“Sheet1”)をアクティブ 33 Workbooks("Book3.xlsx").Worksheets("Sheet1").Activate 34 ' アクティブなシートをコピーして、ブック("Test.xlsm")の1番目のシートの後に挿入 35 ActiveSheet.Copy after:=Workbooks("Test.xlsm").Sheets(1) 36 37 WIth ActiveSheet.UsedRange 38 .Value = .Value 39 End With 40 41End Sub

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

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

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

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

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

guest

回答2

0

ベストアンサー

実際には"一覧表"という文字が含めばという風にしたいです。

開いているブックでブック名に "一覧表" がふくまれているブックを対象にするということでしょうか。

vba

1 2 Dim wb As Workbook 3 For Each wb In Workbooks 4 If wb.Name Like "*一覧表*" Then 5 wb.Worksheets("Sheet1").Activate 6 7 '以下略 8 9 End If 10 Next wb

投稿2021/09/09 04:46

編集2021/09/09 04:47
hatena19

総合スコア34075

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

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

pomiw0000

2021/09/09 05:09

その通りです。ありがとうございます。 あと一つ、質問なのですが この処理をしている前にファイルを開く という以下のコードを記述しています。 Sub ファイル開く() Dim FolderPath, FileName FolderPath = ThisWorkbook.Path & "\ファイル" 'フォルダパスを作成 FileName = Dir(FolderPath & "*") '最初のファイル名を取得 Do While FileName <> "" 'ファイルを開く Workbooks.Open FileName:=FolderPath & "\" & FileName FileName = Dir() '次のファイル名を取得 Loop End Sub 別々にコードを書かずに回答していただいたコードの中に 対象のファイルを開く というコードも一緒に入れたいです。 対象のファイルを開いて他ブックにコピーして閉じる ↓ 次のファイルを開いて他ブックにコピーをして閉じる という繰り返し作業をしたいです。 コード化にすることは可能でしょうか。 また、質問をしてしまい大変申し訳ございません。
hatena19

2021/09/09 05:30

ブックは開いてなくて、特定のフォルダー内のファイル名に"一覧表"を含むブックを開いて、 そのブックのSheet1をコピーするということですね。 説明を省略せずに最初からそのように書いた方かよかったですね。 Sub ファイル開く() Dim FolderPath As String, FileName As String FolderPath = ThisWorkbook.Path & "\ファイル" 'フォルダパスを作成 FileName = Dir(FolderPath & "*") '最初のファイル名を取得 Do While FileName <> "" If FileName Like "*一覧表*" Then 'ファイルを開く Dim wb As Workbook Set wb = Workbooks.Open(FileName:=FolderPath & "\" & FileName) wb.Worksheets("Sheet1").Activate '以下略 wb.Close End If FileName = Dir() '次のファイル名を取得 Loop End Sub
pomiw0000

2021/09/09 06:00 編集

すみません、ありがとうございます! 思い通りに動きました。 わざわざ、二度も答えていただきありがとうございます。
guest

0

Book1,2,3…と番号のところだけ変わるのであれば、

VBA

1FOR I=1 TO N 2 Filename="Book" + Format(I,"###") + ".xlsx" 3 Workbooks(Filename).Worksheets("Sheet1").Activate 4 ' 以下略

が簡単でしょうか

投稿2021/09/09 04:01

ak.n

総合スコア291

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

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

pomiw0000

2021/09/09 04:15

回答ありがとうございます。 Book1.Book2は例で書いてあるだけでありまして、 実際には"一覧表"という文字が含めばという風にしたいです。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問