
はじめて質問させていただきます。
エクセルのマクロで選択された複数シートに順番に
コメントを挿入する・・というのをしたいのですが
うまくいきません。
"Exs.Range("A1").AddComment"の部分で
「実行時エラー:1004 アプリケーション定義またはオブジェクト定義のエラーです」
となってしまいます。
マクロの記録で試そうとも思ったのですが、
複数シートを選択すると、右クリックしても
コメント挿入のメニューが表示されませんでした。
元々、複数シートへのコメント挿入はできないのでしょうか・・?
ソースは以下です。
Sub Macro1()
Dim Exs As Worksheet
Dim sSheet As Long
Dim i As Long
'選択されたシート数を取得
sSheet = ActiveWindow.SelectedSheets.Count
i = 1
'選択されたシート数分、A1セルにコメントをつけていく
Do While i <= sSheet
ActiveWindow.SelectedSheets.Item(i).Activate
Set Exs = ActiveWorkbook.ActiveSheet
Exs.Range("A1").ClearComments
Exs.Range("A1").AddComment
Exs.Range("A1").Comment.Visible = True
Exs.Range("A1").Comment.Text Text:=Chr(10) & "てすとー"
Exs.Range("A1").Select
i = i + 1
Loop
End Sub
お解かりになる方いらっしゃいましたら、
なにとぞよろしくお願いいたします。
No.2ベストアンサー
- 回答日時:
複数シートでもできるようです。
Sheet4とSheet6うお指定しておいて実行したら、Sheet4とSheet6のA1にコメント aaa が入りました。
Sub test01()
Dim sh As Worksheet
For Each sh In ActiveWindow.SelectedSheets
MsgBox sh.Name
sh.Select
sh.Range("A1").ClearComments
sh.Range("A1").AddComment Text:="aaa"
Next sh
End Sub
ご回答ありがとうございます。
シートをActiveではなくSelectにする必要があったのですね。
Excelオブジェクトの扱い方について勉強不足でした・・。
本当にありがとうございました。
No.1
- 回答日時:
こんにちは。
>元々、複数シートへのコメント挿入は
できないようですね。なので解除する必要があるようです。
Dim Exs As Worksheet
Dim Clc As New Collection '■追加
Dim ci As Variant '■追加
'選択されたシートIndexをいったんCollectionに格納
For Each Exs In ActiveWindow.SelectedSheets
Clc.Add Exs.Index
Next Exs
'シートグループ解除
Sheets(1).Select
'選択されたシート数分、A1セルにコメントをつけていく
For Each ci In Clc
With Sheets(ci).Range("A1")
.ClearComments
.AddComment.Text Text:=Chr(10) & "てすとー"
End With
Next ci
な感じで。Collectionではなく、配列でもいいのでしょうけど。
早速のご回答ありがとうございます。
お礼が遅くなってしまって申し訳ありません。
上記の方法で実現できました。
選択シートを1シートづつActiveにするのではなく
Selectにするのがポイント・・だったのですね。
本当にありがとうございました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセルでブック内の倍率がバ...
-
EXCELで複数のシートを一度に「...
-
特定のシートのみ再計算させな...
-
エクセルのシー名を二段表示に...
-
エクセルシートの見出しの文字...
-
エクセルのファイルサイズが急...
-
ハイパーリンクでジャンプした...
-
EXCELの図形(テキストボックス)...
-
【ExcelVBA】マクロの入ったシ...
-
ワークシートそのものの色を変...
-
エクセルを開くとメニューバー...
-
Nintendo Switch 2 キャリング...
-
エクセル シートのグループ化...
-
エクセルでリンク貼り付けした...
-
Wordで差し込み印刷時に表示す...
-
vba Listviewでのチェックボッ...
-
エクセルで複数のシートに画像...
-
EXCELで存在しないシート...
-
Accessのテーブルを既存のExcel...
-
エクセルのシート連番の振り直し
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセルシートの見出しの文字...
-
EXCELで複数のシートを一度に「...
-
エクセルでブック内の倍率がバ...
-
特定のシートのみ再計算させな...
-
【ExcelVBA】マクロの入ったシ...
-
ハイパーリンクでジャンプした...
-
EXCELの図形(テキストボックス)...
-
EXCELで存在しないシート...
-
エクセルで複数のシートに画像...
-
エクセル、特定のシートにパス...
-
エクセルのシー名を二段表示に...
-
ワークシートそのものの色を変...
-
Wordで差し込み印刷時に表示す...
-
Accessのテーブルを既存のExcel...
-
エクセルのファイルサイズが急...
-
エクセルの複数シートでのリン...
-
エクセルで、シートの名前を変...
-
エクセルの2つのシートを並び...
-
EXCELの「シートの見出し」のフ...
-
Excelでマクロ設定したが反映さ...
おすすめ情報