
はじめまして。
VBAはそんなに詳しくないです。
エクセルで、例えば、A1:A5が全てOKになったら、表示している図形を消す。
という事をやりたいです。
セルの値によって表示させる、参照でINDIRECTを使用するものは使いたくないです。
A6に、「{=IF(and(A1:A5="OK"),TRUE,FALSE)}」という式を入れて全てOKになったら、TRUEとなるようにしています。
TRUEになった時に、表示している図形を非表示にする。
FALSEになったら、図形を表示する。
というVBAを作りたいですがうまく行きませんでした。
マウスでチェックボックスをクリックする事で図形のオンオフは出来ましたが、セルの値を変えてチェックボックスをオンオフさせても図形のオンオフができませんでした。
※本来チェックボックスは使用したくないです。
チェックボックスでオンオフ出来るのは知っていたので、計算式でオンオフさせても連動するかと思い試してみましたがダメでした。
使用したVBAは
Private Sub CheckBox1_Click()
.Shapes("myshape").Visible = range("A6").value
End Sub
です。
チェックボックス無しでオンオフするVBAを教えていただけないでしょうか。
No.4ベストアンサー
- 回答日時:
No.1の回答者です。
途中から話が変わってくるとやりにくいですね。
Private Sub Worksheet_Change(ByVal Target As Range)
If Target.Address = "$BE$14" Then ←これでは、コールしないです。イベントが発生していません。
Select Case Range("BE14").Value
Target (該当するセル)そのものからイベントが発生するわけではないからです。
もちろん、どんなイベントでも、自作イベントなら、イベントは可能にしますが、既存のイベントを利用したいというのが、こちらの本音です。No.2さんのCalculate イベントは、Now関数など、揮発性関数を使い自分で値が変わる関数をおいてあげないと、イベントが発生しなかったと思います。
イベントはどこであろうが、Range("BE14")の値を取れば済むことですが、それでは頻繁にイベントが発生してしまうので、除外項目が必要です。
Worksheet_Change は、[Enter] によって起動しますから、
[BE14] ここに、数式があって、OK/NGの文字が入るというのでしょうか。
{=IF(and(A1:A5="OK"),"OK","NG")}
むろん、TRUE/FALSE なら、=COUNTIF($A$1:$A$5,"OK")=5 これで済むわけですが。
今回は、=IF(COUNTIF($A$1:$A$5,"OK")=5,"OK","NG")
に入れ替えました。
>例えば、A1:A5が全てOKになったら、
どういうイベントで、OK/NGの値が変わるか、質問では肝心な所は書かれていませんので、これでうまくいくとは限りません。
例えば、1.ワークシートへの手動による入力、2.OLEコントロールでの自動変更、3.DDEからの自動変更、これらの条件によってイベントは変わる可能性が強いです。だから、以下が有効なのは、1に限ります。
'//シートモジュール
Private Sub Worksheet_Change(ByVal Target As Range)
If Intersect(Target, Range("BE14").Precedents) Is Nothing Then Exit Sub
If Range("BE14").Value = "OK" Then
Shapes("MyShape").Visible = msoTrue
Else
Shapes("MyShape").Visible = msoFalse
End If
End Sub
ただ、このイベントは、シートをまたいで別のシートからイベントが取れないと思います。その場合は、途中の中継点が必要だったような気がします。
最初のTRUE/FALSEでうまくいかなかったので途中で仕様を変えてしまいました。
大変申し訳ありません。
WindFallerさんのおっしゃる通り、Worksheet_ChangeではEnterを押したときしか反応しませんでしたので、fujillinさん(No.2さん)のヒントと、WindFallerさんから頂いた回答を元に、再度組みなおしてみたところ成功することが出来ました。
A1:A5についてですが、それぞれ計算式が入っています。
***A3~A5に入っている計算式
=IF(B1="","NG","OK")
※A2には「B2=””」が入っています
B1~B2に入っている計算式は
=IF(P7="","",1)
B1はP7、B2はR7とリンクしていて、P7,R7に何か入力されたらA1:A2がOKとなるようにしています。
***A3~A5に入っている計算式
=IF(B3=0,"NG","OK")
※A4には「B4=0」、A5「B5=0」が入っています。
B3~B5はオプションボタンとリンクしていて、それぞれどれかにチェックが入ったら1~5の数字が出るようになっています。
リンクさせているオプションボタンそれぞれにチェックが入ればOKとなるようにしています。
そして、これらのA1~A5がすべてOKになればBE14がOKの文字が出るようにしました。
詳しい説明を省いてしまい大変お手数おかけしました。
本来でしたら、お二人から頂いたご回答どちらも参考にさせていただいて成功することが出来たので、どちらの回答にもベストアンサーを付けたいのですが、いろんな可能性を考えて頂いたWindFallerさんをベストアンサーとさせていただきました。
最終的に以下でうまくいきました。
Private Sub Worksheet_Calculate()
Select Case Range("BE14").Value
Case "NG"
ActiveSheet.Shapes("myshape").Visible = True
Case "OK"
ActiveSheet.Shapes("myshape").Visible = False
End Select
End Sub
本当にありがとうございました。
No.3
- 回答日時:
No2です
>指定したコレクションに対するインデックスが境界を超えています
図形をうまく指定できていない雰囲気ですね。
Shapesオブジェクトはブック全体で共通のようですが、別シート上の図形になっているとかはないですよね?
あるいは、図形を名前ではなくインデックス(=番号)で指定しても取得できませんか?
または、Shapesを .Shapesとしてみるとか・・・
エディタのウォッチ式でShapes等を調べてみると、なぜ取得できないのかに関するヒントが得られるかも知れません。
返答が遅れてしまい申し訳ありませんでした。
やはり、shapesの値が取得できていませんでした。
fujillinさんに頂いたアイデアを参考にCalculateを用いて再度考え直して成功する事が出来ました。
ありがとうございました!
Private Sub Worksheet_Calculate()
Select Case Range("BE14").Value
Case "NG"
ActiveSheet.Shapes("myshape").Visible = True
Case "OK"
ActiveSheet.Shapes("myshape").Visible = False
End Select
End Sub
No.2
- 回答日時:
こんにちは
A6セルには、ご提示の関数式が設定されているものとして…
アイデアのみですが、シートモジュールに以下を設定しておくのではいかが?
Dim B As Boolean
Const spName = "myshape"
Private Sub Worksheet_Activate()
B = Shapes(spName).Visible
End Sub
Private Sub Worksheet_Calculate()
If Range("A6").Value <> B Then
B = Range("A6").Value
Shapes(spName).Visible = B
End If
End Sub
ご回答ありがとうございます。
モジュールに記述したところ、
下から3行目の
〉shapes(spNane).Visible =B
で、指定したコレクションに対するインデックスが境界を超えています。とエラーが起きてしまいました。
自分なりにアレンジしてみたのですが結局はダメでした…。
もう少し勉強します。。
No.1
- 回答日時:
>計算式でオンオフさせても連動するかと思い試してみましたがダメでした。
'//シートモジュール
Private Sub Worksheet_Change(ByVal Target As Range)
If Range("A6") Then
Shapes("MyShape").Visible = msoTrue
Else
Shapes("MyShape").Visible = msoFalse
End If
End Sub
しかし、数式自体が他から変更を受ける場合は、別のイベントがが必要になります。
お返事ありがとうございます。
その後試行錯誤した結果、下記にたどり着いたのですが、WindFallerさんが仰る通り、数式は他から変更を受けるため反応しませんでした。
何か方法を教えていただけますでしょうか。
下記は、BE14に指定した範囲のセルが全てOKになったらOK、そうじゃなければNGかを表示する計算式が入っています。
Private Sub Worksheet_Change(ByVal Target As Range)
If Target.Address = "$BE$14" Then
Select Case Range("BE14").Value
Case "NG"
ActiveSheet.Shapes("myshape").Visible = True
Case "OK"
ActiveSheet.Shapes("myshape").Visible = False
End Select
End If
End Sub
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) Excelのマクロコードについて教えてください。 1 2022/06/19 10:08
- Excel(エクセル) エクセルVBAでチェックボックスにチェックを入れる 1 2022/09/14 00:52
- PowerPoint(パワーポイント) ExcelのVBAコードについて教えてください。 3 2022/05/25 14:32
- Visual Basic(VBA) エクセルのマクロについて教えてください。 4 2023/03/02 08:40
- Excel(エクセル) Excelのマクロについて教えてください。 4 2022/05/31 14:07
- Visual Basic(VBA) Excel VBAの解読について質問があります。 概要は、マクロでチェックボックスにチェックすると日 1 2023/02/10 07:50
- Visual Basic(VBA) EXCEL VBAにて動的にCheckBOXを複数作成し、同BOXにイベントを追加したい 1 2023/03/16 07:05
- Visual Basic(VBA) エクセルのマクロについて教えてください。 1 2023/03/07 14:05
- Excel(エクセル) ワードのマクロについて教えてください。 1 2023/03/11 13:50
- Visual Basic(VBA) Excelのマクロコードについて教えてください。 1 2022/03/27 13:25
このQ&Aを見た人はこんなQ&Aも見ています
-
今年はじめたいことは?
今年はこれをはじめたい!ということを教えてください!
-
初めて自分の家と他人の家が違う、と意識した時
子供の頃、友達の家に行くと「なんか自分の家と匂いが違うな?」って思いませんでしたか?
-
今の日本に期待することはなんですか?
目まぐるしく、日本も世界も状況が変わる中、あなたが今の日本に期待することはなんですか?
-
この人頭いいなと思ったエピソード
一緒にいたときに「この人頭いいな」と思ったエピソードを教えてください
-
【お題】斜め上を行くスキー場にありがちなこと
運営も客も一流を通り越して斜め上を行くスキー場にありがちなことを教えて下さい。
-
エクセルで条件をつけて図形を表示する方法を教えてください。例えば、セルA1に入力された数値が100以
Excel(エクセル)
-
セルの内容の条件に応じて図形の表示をしたりしなかったりする
Excel(エクセル)
-
条件に一致したときに画像を表示したいのですが・・。
Excel(エクセル)
-
-
4
エクセルで図形を連動させたい
Excel(エクセル)
-
5
Excelで数字を入れたら対応する図を呼び出したい
Excel(エクセル)
-
6
Excel VBA インデックスの境界について
Excel(エクセル)
-
7
チェックボックスをオンにしたとき図が出るようにしたいのです。
Access(アクセス)
-
8
コンボボックス内の文字サイズ変更
Excel(エクセル)
-
9
VBAで保存しないで閉じると空のBookが残る
Excel(エクセル)
-
10
オートシェイプの削除時のエラー回避法
Visual Basic(VBA)
-
11
エクセル イベントマクロ Changeイベントを複数作りたい
Access(アクセス)
-
12
セルをクリック⇒そのセルに入力された文字を○で囲む
Excel(エクセル)
-
13
エクセルで条件を付けて丸を付ける関数を教えてください。
Excel(エクセル)
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・一番好きなみそ汁の具材は?
- ・泣きながら食べたご飯の思い出
- ・「これはヤバかったな」という遅刻エピソード
- ・初めて自分の家と他人の家が違う、と意識した時
- ・いちばん失敗した人決定戦
- ・思い出すきっかけは 音楽?におい?景色?
- ・あなたなりのストレス発散方法を教えてください!
- ・もし10億円当たったら何に使いますか?
- ・何回やってもうまくいかないことは?
- ・今年はじめたいことは?
- ・あなたの人生で一番ピンチに陥った瞬間は?
- ・初めて見た映画を教えてください!
- ・今の日本に期待することはなんですか?
- ・集中するためにやっていること
- ・テレビやラジオに出たことがある人、いますか?
- ・【お題】斜め上を行くスキー場にありがちなこと
- ・人生でいちばんスベッた瞬間
- ・コーピングについて教えてください
- ・あなたの「プチ贅沢」はなんですか?
- ・コンビニでおにぎりを買うときのスタメンはどの具?
- ・おすすめの美術館・博物館、教えてください!
- ・【お題】大変な警告
- ・洋服何着持ってますか?
- ・みんなの【マイ・ベスト積読2024】を教えてください。
- ・「これいらなくない?」という慣習、教えてください
- ・今から楽しみな予定はありますか?
- ・AIツールの活用方法を教えて
- ・最強の防寒、あったか術を教えてください!
- ・歳とったな〜〜と思ったことは?
- ・モテ期を経験した方いらっしゃいますか?
- ・好きな人を振り向かせるためにしたこと
- ・スマホに会話を聞かれているな!?と思ったことありますか?
- ・それもChatGPT!?と驚いた使用方法を教えてください
- ・見学に行くとしたら【天国】と【地獄】どっち?
- ・これまでで一番「情けなかったとき」はいつですか?
- ・この人頭いいなと思ったエピソード
- ・あなたの「必」の書き順を教えてください
- ・14歳の自分に衝撃の事実を告げてください
- ・人生最悪の忘れ物
- ・あなたの習慣について教えてください!!
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Excelのマクロについて教えてく...
-
エクセルVBA 段落番号自動取得方法
-
VBAの「To」という語句について
-
ExcelのVBAコードについて教え...
-
質問58753 このコードでうまく...
-
VBAでユーザーフォームを指定回...
-
以下のプログラムの実行結果は...
-
VBAでFOR NEXT分を Application...
-
VBAについてです。 どなたかご...
-
VBA 最終行の取得がうまくいか...
-
Excel マクロについて詳しい方...
-
算術演算子「¥」の意味について
-
Excelのマクロについて教えてく...
-
VBAでセルの書式を変えずに文字...
-
【ExcelVBA】値を変更しながら...
-
Excel 範囲指定スクショについ...
-
えくせるのVBAコードについて教...
-
エクセルのVBAコードについて教...
-
VBA 同じフォルダ内のすべての...
-
エクセルでCDOを使ったメール送...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
VB.net 文字列から日付型へ変更...
-
VBA 最終行の取得がうまくいか...
-
VBAでエクセルのテキストデータ...
-
【ExcelVBA】5万行以上のデー...
-
エクセルVBAで在庫の組み換え処...
-
VBAから書き込んだ条件付き初期...
-
エクセルのVBAコードについて教...
-
VBAでユーザーフォームを指定回...
-
エクセルのVBAについて教えてく...
-
vbaマクロについて
-
ExcelのVBAコードについて教え...
-
【VBA】 結合セルに複数画像と...
-
WindowsのOutlook を VBA から...
-
質問58753 このコードでうまく...
-
ExcelのVBAコードについて教え...
-
Excel VBAについて。こんな動作...
-
[Excel VBA]特定の条件で文字を...
-
[VB.net] ボタン(Flat)のEnable...
-
エクエルのVBAコードについて教...
-
ExcelのVBAコードについて教え...
おすすめ情報