
【質問したい事】
マクロが保存されているブックとは別のブックに
対して、for next ステートメントを実行したいです
以下コードまで考え、普通に動いています
これで良いのでしょうか?
For i = 2 To Cells(Rows.Count, 1).End(xlUp).Row
の文から、何も、別ブック・別シートについて、指定してないのですが
ちゃんと、別ブックに飛んで動いています
理屈等、分かる方いましたら、教えてください
【別のブックに対してのfor nextステートメント】
Sub 抽出()
Dim kagamibook As Workbook
Dim kagamisheet As Worksheet
Dim filePath As String
filePath = "C:\Users\2020\OneDrive\マクロ\240820_あいうえお.xlsm"
Set kagamibook = Workbooks.Open(filePath)
Set kagamisheet = kagamibook.Sheets("ボタン作成先シート")
For i = 2 To Cells(Rows.Count, 1).End(xlUp).Row
If Cells(i, 3) = "条件1" Or Cells(i, 3) = "条件1" Then
Cells(i, 5) = Cells(i, 1)
End If
Next i
End Sub
A 回答 (2件)
- 最新から表示
- 回答順に表示
No.2
- 回答日時:
理屈はNo.1にある通りで、たまたま操作したいシートがアクティブになっただけなので、「これで良いのでしょうか?」についてはあまり良くないですね。
操作したいシートを明示的に指定するかActivateした方が間違いないです。No.1
- 回答日時:
こんにちは
>理屈等、分かる方いましたら、教えてください
For文の中に記述している「Cells(i, 3)」等は、ブックもシートも指定していないので、エクセルは暗黙の指定としてアクティブシートのセルとして解釈します。
単純に、そういう仕組みになっているだけです。
意図してかどうかはわかりませんけれど、For文の前で、
> Set kagamibook = Workbooks.Open(filePath)
で、「240820_あいうえお.xlsm」のブックを開いていますので、その結果、開いたブックがアクティブになります。
一方で、アクティブなシートは、そのブックの成り行きです。
たまたま保存時のシートが質問者様が意図したシート(=ボタン作成先シート?)
だったのではないかと想像します。
別のシートをアクティブにした状態で保存してあると、次に開いた際にはそちらのシートがアクティブになりますので、ご提示の処理を実行した場合は、そちらのシートに対して実行されることになると思われます。
アクティブなブックやシートを、マクロはまずよんでいくんですね
こちらは、意図していなかったです
大変、勉強になりました。ありがとうございます
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
VBAでブックを非表示で開いて処...
-
エクセルを共有するとPCによっ...
-
エクセルの関数 ENTERを押...
-
Excelでブックの共有を掛けると...
-
エクセルを開くと最大化などの...
-
【マクロ】【画像あり】❶ブック...
-
Excelファイルをダブルクリック...
-
Excel(2010)のフィルターが保...
-
「ブックの共有」を有効にして...
-
ブックのピボットを別ブックに...
-
指定ファィルの指定シートをシ...
-
Excelの警告について
-
【マクロ】【画像あり】ファイ...
-
USBフラッシュメモリーのエクセ...
-
エクセルでウィンドウの枠固定...
-
複数エクセルから特定シートの...
-
エクセルシートの一部を送りたい
-
Excelで指定範囲のデータ...
-
エクセルファイルをオープンし...
-
参照したいブックのパス名に"["
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
【マクロ】アクティブセルの時...
-
エクセルの関数 ENTERを押...
-
VBAでブックを非表示で開いて処...
-
エクセルを共有するとPCによっ...
-
WorkBooksをオープンさせずにシ...
-
エクセルで参照しているデータ...
-
Excelファイルをダブルクリック...
-
Excelでブックの共有を掛けると...
-
「ブックの共有」を有効にして...
-
Excel(2010)のフィルターが保...
-
Excelの新しい空白のブックを開...
-
同じフォルダへのハイパーリン...
-
フォルダ内の複数ファイルから...
-
エクセルで別ブックをバックグ...
-
別ブックから入力規則でリスト...
-
ブックのピボットを別ブックに...
-
エクセルでウィンドウの枠固定...
-
エクセルにおける,「ブック」...
-
Excelで複数ブックの同一セルに...
-
Excelで指定範囲のデータ...
おすすめ情報