
excelでカレンダーコントロールを設定しました。
ターゲットとしているセルが、結合セルなのですが、うまく表示されません。セルの結合を解除すればうまくいきます。
しかし、ターゲットのセルは結合させておきたいので、何か解決策はありますでしょうか?
以下、コードの内容です。
■フォームコード
Private Sub Calendar1_DblClick()
ActiveCell.Value = Me.Calendar1.Value
End Sub
■シートコード
Private Sub Worksheet_SelectionChange(ByVal Target As Range)
If Target.Address <> "$A$6" And Target.Address <> "$A$13" And Target.Address <> "$A$20" And Target.Address <> "$A$27" Then Exit Sub
UserForm1.Show
End Sub
No.1ベストアンサー
- 回答日時:
これでいけるのではないかという案を。
どのセルが結合しているのかわかりませんが
仮に「A6とB6」が結合されているのでしたら
Target.Address <> "$A$6" を
Target.Address <> "$A$6:$B$6" ←と、
このように変えてみてはいかがでしょうか?
ワイルドカードを使う方法も考えてみましたが
ターゲットが「AA67」などの場合にも
誤作動してしまいそうなのでこの方法を提案します。
ご回答ありがとうございます!
結合しているセルはA6~A8でした。
ご回答を参考に$A$6:$A$8でやってみたところ、うまくいきました!
ありがとうございましたm(_ _)m
No.2
- 回答日時:
>ターゲットとしているセルが、結合セルなのですが、うまく表示されません
うまく表示されないとは、UserFormが表示されないということですよね?
例えば、セルA6:A9 が結合されていたら、
Target.Addressは、$A$6:$A$9と結合セルの3セルのアドレスになります。
で、If Target.Address <> "$A$6"
この結果は、常にTRUEになり質問のような結果になります。
結合セルありの場合でもうまくいくようにする方法を2つ提示しておきます。
'●(1)選択したセルの先頭セルのアドレスを比較-------
Private Sub Worksheet_SelectionChange(ByVal Target As Range)
If Target.Cells(1).Address <> "$A$6" And _
Target.Cells(1).Address <> "$A$13" And _
Target.Cells(1).Address <> "$A$20" And _
Target.Cells(1).Address <> "$A$27" Then Exit Sub
UserForm1.Show
End Sub
'●(1)Intersecメソッドを使う方法----------------
Private Sub Worksheet_SelectionChange(ByVal Target As Range)
If Intersect(Target, Range("A6,A13,A20,A27")) Is Nothing Then Exit Sub
UserForm1.Show
End Sub
'-----------------------------------------
以上です。
ご回答ありがとうございます!
>うまく表示されないとは、UserFormが表示されないということですよね?
→はい、その通りです。
基本的な用語も使えず、お恥ずかしい限りです(><;)
間違っていた理由も分かりやすいご説明のおかげで、理解できました!
>●(1)Intersecメソッドを使う方法
他サイトで参考させていただいたなかに、ご提示のコード表示がありましたが、いまいち理解できず、If Target.Address <> "$A$6"にしていました。
今後も勉強していきます。ありがとうございましたm(_ _)m
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) ExcelのVBAコードについて教えてください。 2 2022/05/26 17:19
- Visual Basic(VBA) ExcelのVBAコードについて教えてください。 2 2022/06/10 11:06
- Visual Basic(VBA) 【VBA】写真の貼り付けコードがうまく機能しません。 5 2022/09/01 18:43
- Excel(エクセル) B列に文字がはいったらA列に数字が入るマクロードを完成させたい 4 2023/04/21 01:58
- Visual Basic(VBA) エクセル VBAについて 2 2022/05/16 16:33
- Visual Basic(VBA) エクセルのVBAでダブルクリックでチェックを入れたあと 1 2022/10/26 20:30
- Visual Basic(VBA) ExcelのVBAコードについて教えてください。 3 2022/06/10 09:24
- Excel(エクセル) エクセルのイベントプロシージャーでF列の最終行のセルの入力をトリガーにしたいのですが 1 2022/10/14 09:36
- Visual Basic(VBA) ExcelのVBAコードについて教えてください。 1 2023/02/02 09:25
- Visual Basic(VBA) 【Excel VBA】自動メール送信の機能追加 5 2022/09/29 12:53
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセルの関数について
-
エクセル GROUPBY関数について...
-
Excelで4択問題を作成したい
-
エクセルの複雑なシフト表から...
-
エクセル
-
Amazonでマイクロソフトオフィ...
-
エクセルシートの見出しの文字...
-
グループごとの個数をカウント...
-
【マクロ】変数に入れるコード...
-
エクセルのリストについて
-
【マクロ】別ファイルへマクロ...
-
グループごとの人数のカウント
-
エクセルについて
-
グループごとの人数のカウント
-
【マクロ】左のブックと右のブ...
-
【マクロ】元データと同じお客...
-
【マクロ】数式を入力したい。...
-
【マクロ】【相談】Excelブック...
-
【マクロ】実行時エラー '424':...
-
他のシートの検索
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
9月17日でサービス終了らし...
-
エクセル
-
【マクロ】WEBシステムから保存...
-
エクセルの循環参照、?
-
エクセル ドロップダウンリスト...
-
エクセルのdatedif関数を使って...
-
特定のセルだけ結果がおかしい...
-
【マクロ】A列にある、日付(本...
-
【マクロ】EXCELで読込したCSV...
-
【マクロ】アクティブセルの時...
-
【エクセル】期限アラートについて
-
iPhoneのExcelアプリで、別のシ...
-
【関数】同じ関数なのに、エラ...
-
Excelの新しい空白のブックを開...
-
【マクロ】3行に上から下に並...
-
【マクロ】宣言は、何のために...
-
VBA チェックボックスをオーバ...
-
Excelについての質問です 並べ...
-
【マクロ】アクティブセルの2...
-
【関数】不規則な文章から●●-●●...
おすすめ情報