海外旅行から帰ってきたら、まず何を食べる?

はじめて質問させていただきます。
エクセルのマクロで選択された複数シートに順番に
コメントを挿入する・・というのをしたいのですが
うまくいきません。

"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

お解かりになる方いらっしゃいましたら、
なにとぞよろしくお願いいたします。

A 回答 (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
    • good
    • 0
この回答へのお礼

ご回答ありがとうございます。

シートをActiveではなくSelectにする必要があったのですね。
Excelオブジェクトの扱い方について勉強不足でした・・。

本当にありがとうございました。

お礼日時:2006/04/19 09:23

こんにちは。


>元々、複数シートへのコメント挿入は
できないようですね。なので解除する必要があるようです。

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ではなく、配列でもいいのでしょうけど。
    • good
    • 0
この回答へのお礼

早速のご回答ありがとうございます。
お礼が遅くなってしまって申し訳ありません。
上記の方法で実現できました。

選択シートを1シートづつActiveにするのではなく
Selectにするのがポイント・・だったのですね。

本当にありがとうございました。

お礼日時:2006/04/19 09:19

お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!

このQ&Aを見た人はこんなQ&Aも見ています