
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で質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
【関数】=EXACT(a1,b1) a1とb1...
-
【マクロ】excelファイルを開く...
-
エクセルのリストについて
-
【マクロ】【相談】Excelブック...
-
エクセルの関数について
-
【マクロ】数式を入力したい。...
-
【マクロ】元データと同じお客...
-
【マクロ】実行時エラー '424':...
-
他のシートの検索
-
【マクロ】左のブックと右のブ...
-
【画像あり】オートフィルター...
-
Office2021のエクセルで米国株...
-
LibreOffice Clalc(またはエク...
-
vba テキストボックスとリフト...
-
エクセルのVBAで集計をしたい
-
【マクロ】【配列】3つのシー...
-
エクセルシートの見出しの文字...
-
【マクロ】【画像あり】ファイ...
-
【マクロ】【画像あり】❶ブック...
-
【マクロ画像あり】❶1つの条件...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
【マクロ】元データと同じお客...
-
エクセルの関数について
-
【画像あり】オートフィルター...
-
エクセルのVBAで集計をしたい
-
エクセルのリストについて
-
【マクロ】数式を入力したい。...
-
【マクロ】【相談】Excelブック...
-
Office2021のエクセルで米国株...
-
【マクロ】実行時エラー '424':...
-
他のシートの検索
-
エクセルの複雑なシフト表から...
-
【マクロ】【配列】3つのシー...
-
vba テキストボックスとリフト...
-
【マクロ】左のブックと右のブ...
-
【マクロ】変数に入れるコード...
-
エクセルシートの見出しの文字...
-
【マクロ】別ファイルへマクロ...
-
【関数】同じ関数なのに、エラ...
-
Amazonでマイクロソフトオフィ...
-
ページが変なふうに切れる
おすすめ情報