
No.1ベストアンサー
- 回答日時:
Sheet1だとして、
Sheet1のマクロで
Private Sub Worksheet_SelectionChange(ByVal Target As Range)
'
If Target.Column = 1 And Target.Row >= 5 And Target.Row <= 20 Then
If Target.Value <> "" Then MsgBox "入力済み"
End If
'
End Sub
と入れると、クリックしたセルがA5からA20のどれかで
かつセルに値が入っているときのみ”入力済み”とメッセージが表示されます。
このメッセージ表示の部分を、「名前を付けて保存」の処理に置き換えてはいかがでしょうか。
No.3
- 回答日時:
シートをクリックしただけで発生するイベントは無いのではないでしょうか・・ダブルクリックなら BeforeDoubleClickイベントで取得できるのですが。
できればダブルクリックやボタンでのファイル保存に仕様変更されてはいかがでしょう。多少強引なやりかたとしては、次のような方法もあるにはあります。
(1)A5~A20全てのセルに、セルと同じ大きさテキストなしのラベル(フォームツールバーのほうです)を貼り付け、それぞれにマクロを登録する
(2)登録したマクロのプロシージャ内で、クリックされたオートシェープの名前等によりクリックされたことにするセルを判断する
(3)マクロプロシージャ内にセルのselectメソッドを書いておけば、見た目上はほぼセルがクリックされてイベントが発生したように見えます
SelectionChangeイベントではキーボードによるセル移動などにも反応してしまったり、現在選択されているセルをクリックしても反応しないという問題があります。changeイベントはセルの値が変更されなければクリックしても反応が無い状態になってしまいます。結果としてこのように面倒な方法しか思いつかないのですが、仕様を少し変更していずれかのワークシートイベントを取得して作業させる方が良い気がします。
お礼が遅くなりまして申し訳ありません。
色々な方法があるのですね。大変勉強になります。
今回は#1さんの方法で対応いたしました。
今後、変更などする際にBraveStoryさんの方法も
参考にさせていただきたいと思います。
ご回答ありがとうございました。
No.2
- 回答日時:
CHANGEの方が適当かなと思いまして。
Private Sub Worksheet_Change(ByVal Target As Range)
a = Target.Row
b = Target.Column
If a >= 5 And a <= 20 And b = 1 Then
If Target.Value = "" Then
MsgBox "値入力なし"
Else
flname = InputBox("ファイル名=")
ActiveWorkbook.SaveAs Filename:=flname
End If
Else
msgbox "範囲外入力です"
End If
End Sub
お礼が遅くなり申し訳ありませんでした。
今回のマクロは#1さんの方法で実行させていただきました
Changeという新しい情報をしり今後は色々使い分けたいと思います。
勉強になりました。ご回答ありがとうございました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- その他(データベース) Accessフォームからパラメーターで表示したレコードを指定のExcelのセルへ転送する方法について 2 2022/08/22 18:04
- Visual Basic(VBA) エクセルのマクロについて教えてください。 3 2023/02/22 08:53
- Visual Basic(VBA) ExcelのVBAコードについて教えてください。 1 2023/04/21 13:46
- Visual Basic(VBA) Outlook VBAについて 1 2023/07/10 12:41
- Excel(エクセル) 【EXCEL】=セル&セルが上手く表示できない。 7 2022/09/04 21:32
- Excel(エクセル) コントロールにリンクするセルが選択されない 3 2022/06/12 14:37
- Visual Basic(VBA) ExcelのVBAコードについて教えてください。 2 2023/01/23 17:13
- Excel(エクセル) エクセルにサムネイル画像組み込み 2 2022/09/02 17:13
- Visual Basic(VBA) ExcelのVBAコードについて教えてください。 2 2023/05/23 16:28
- Excel(エクセル) 【マクロ】ボタンを押すごとに、A1セル、A2セル、A3セルに日付を入力 3 2023/01/25 00:12
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
A1から最下行までを選択するVBA
-
ExcelVBAでセルの番地を変数と...
-
データを入力後、セルの数値を...
-
Excel VBAのInpuboxの文字列
-
Excelマクロ セルを行頭に移動
-
OfficeExcel2003:マクロを用い...
-
セルを選択するマクロ(エクセル)
-
VBA 変数Variantは万能??
-
VBAに関する質問
-
EXCELでの変数によるMacro自動...
-
同じ行だが、A列を選択させるマ...
-
5桁の数字どうしの要素比較
-
EXCEL2010のマクロで、セル位置...
-
vbaで指定したセルより下の行を...
-
[VBA] セル内の文字を取得して...
-
CutCopyMode範囲の取得方法につ...
-
エクセル2010のマクロについて...
-
Excelでのセルに挿入するコメン...
-
excel マクロでの特殊文字入力方法
-
VBA Rangeの足し算
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
vbaで指定したセルより下の行を...
-
エクセルでセルをクリックする...
-
VBAでの SendKeysの変数指定方法
-
Excel VBA:フォーム←→セルのア...
-
エクセルマクロで「セルのサイ...
-
Excelマクロ セルを行頭に移動
-
マクロのデータ削除
-
セルをクリックしたら色を変え...
-
IF関数で違う値もTRUEになる
-
Excel VBA で色付きのセルの値...
-
excel マクロでの特殊文字入力方法
-
【EXCEL-VBA】特定の値の入った...
-
(エクセルVBA)セルを左クリッ...
-
ロックされていないセル内をクリア
-
ダブルクリックでセルに色をつ...
-
ファイルサーバー上のexcelファ...
-
Excelでプルダウンからフィルタ...
-
VBA Rangeの足し算
-
【VBA】アクティブセルだけ背景...
-
ExcelVBA コンボボックスに入力...
おすすめ情報