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

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

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

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

Visual Basic .NET

Microsoft Visual Basic .NET (VB.NET)とはオブジェクト志向のプログラム言語です。 Microsoft"s Visual Basic 6 のバージョンアップとしてみることができますが、Microsoft.NET Frameworktによって動かされています。

Q&A

解決済

2回答

1232閲覧

VBAの5つExcelファイルを1つにまとめるフォルダでエラーが出ます。

JetSzero

総合スコア8

VBA

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

Visual Basic .NET

Microsoft Visual Basic .NET (VB.NET)とはオブジェクト志向のプログラム言語です。 Microsoft"s Visual Basic 6 のバージョンアップとしてみることができますが、Microsoft.NET Frameworktによって動かされています。

0グッド

0クリップ

投稿2021/07/07 10:39

編集2021/07/07 10:43

VBAの質問です。
同じフォルダにあるExcel5つを同じExcelsheetにまとめるマクロを作ろうと思っています。
しかし、実行してもエラーになります。
どこが悪いのでしょうか?

VBA

1Sub ファイル読み込み() 2 3Dim wb As Workbook 4Dim i As Integer 5Dim a As Integer 6Dim Filename As String 7Dim IsBookOpen As Boolean 8Dim OpenBook As Workbook 9 10 11With CreateObject("WScript.Shell") 12 13 .currentDirectory = "フォルダ場所" 14 15End With 16 17 18Filename = Dir("*.xlsx") 19 Set wb = Workbooks.Open(Filename:=Filename, UpdateLinks:=3, ReadOnly:=True) 20 21 ThisWorkbook.Sheets("グラフ作成").Range("B2:B7").Value = wb.Sheets("sheet1").Range("B2:B7").Value 22 wb.Close savechanges:=falese 23 24Do While Filename <> "" 25 26 Set wb = Workbooks.Open(Filename:=Filename, UpdateLinks:=3, ReadOnly:=True) 27 28 29 For i = 3 To 5 30 ThisWorkbook.Sheets("グラフ作成").Range(Cells(2, i), Cells(7, i)).Value = wb.Sheets("sheet1").Range("C2:C7").Value 31 Next i 32 33 wb.Close savechanges:=falese 34 35 36Loop 37 wb.Close savechanges:=falese 38 39End Sub 40

イメージ説明

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

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

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

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

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

jinoji

2021/07/07 10:48 編集

多分エラーの原因ではないと思いますが、faleseはFalseのスペルミスですね。
JetSzero

2021/07/07 10:51

ご指摘ありがとうございます。 エラーの原因は分かりませんか?
guest

回答2

0

投稿2021/07/07 11:45

syousuke.33

総合スコア312

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

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

0

ベストアンサー

頭にシート名をつけずにCellsとかRangeとかを使うと、ActiveSheetが省略されたとみなされるので、
複数のシートを扱う場合思わぬエラーの原因になります。

ファイルをOpenするとそれがActiveWorkbookになるので、
いまエラーが起きている箇所でThisWorkbook.Sheets("グラフ作成")の中のセルを指定しているつもりのところが、別のシートを指定することになってしまい、エラーになったのでしょう。
たとえば以下のように直したらうまくいく気がします。

vba

1Dim ws As Worksheet 2set ws = ThisWorkbook.Sheets("グラフ作成") 3'(略) 4ws.Range(ws.Cells(2, i), ws.Cells(7, i)).Value = wb.Sheets("sheet1").Range("C2:C7").Value 5'(略) 6

投稿2021/07/07 10:50

編集2021/07/07 10:58
jinoji

総合スコア4592

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

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

JetSzero

2021/07/07 11:22

エラーはなくなって3列目まではデータが入力されるようになったのですが、残り2列分が表示されません。 また、実行が永遠と続いて終了しません。 原因分かりますか? 何度もすみません。
jinoji

2021/07/07 11:29

ループの最後に次のファイルを読み込まないからでは? Filename = Dir()
jinoji

2021/07/07 11:34

グラフ作成シートの C2:C7、D2:D7、E2:E7 のそれぞれに sheet1のC2:C7をセットするというのがやりたいことですか?
jinoji

2021/07/07 12:05

なんかファイルを開くたびに同じシートの同じセルに転記してしまうように思えるのですが。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問