
こんにちは。
エクセルのチェックボックスについて一括でチェックをはずす方法を教えて頂きたいのですが、
チェックボックスにチェックを入れると自動で指定した範囲から価格を持ってくるという関数を使ったファイルを作成しました。
下記の(1).(2)の方法でそのチェックボックスのチェックを一括ではずすことは可能でしょうか?
(1)そのファイルをチェックが入った状態で保存し閉じても、
再度ファイルを開いた段階で、すべてのチェックがはずれている。
(2)普通の数値が入ったセルに関しては”記録マクロ”を使用し、ボタンを押せば、数値が削除されるという事はできました。
それと同じような感じでボタンを押せば、チェックがはずれる。
もし(1).(2)の方法で可能であればその方法を教えて頂けないでしょうか?
また、両方とも不可能ならば他の方法でチェックボックスを一括で外す方法教えて頂けないでしょうか?
ちなみに、私は基本的な関数などは問題なく使用できますが、記録マクロに関しても初めて使用した程度のエクセル認識力ですので、いくつか方法があるならば、一番簡単だと思われる方法を教えて頂きたいです。
知識不足でお恥ずかしいですが、
ぜひ、教えて頂けます様、宜しくお願いいたします。
No.3ベストアンサー
- 回答日時:
(1)
>普通の数値が入ったセルに関しては”記録マクロ”を使用し、
決めたセルの値を0か空白にするのは、マクロの記録でそのものズバリとか、推測で少し変えて、できます。実際済んだようです。
しかしこれはVBAを使わないとできなかったわけです。
ーー
同じように
(2)
>チェックボックスについて一括でチェックをはずす方
のもVBAを使わないとできないでしょう。違うのは、(1)と違って
マクロの記録が使えない、ことです。操作しても記録しない。
それでVBAの基本に戻って、それも中上級的にむつかしい、コントロールの扱いのコードを作らなければなりません。
10数個以内のチェックボックスなら
Private Sub CommandButton1_Click()
CheckBox1.Value = False
CheckBox2.Value = False
CheckBox3.Value = False
CheckBox4.Value = False
CheckBox5.Value = False
End Sub
のようなのをやってみてはどうですか。
ただAuto_Open()ないなどでは
Sub test01()
With Worksheets("Sheet3")
.CheckBox1.Value = False
.CheckBox2.Value = False
.CheckBox3.Value = False
.CheckBox4.Value = False
.CheckBox5.Value = False
End With
End Sub
でないといけないかも知れない。
色々必要付帯知識が多く、私もわかってない点があるかもしれないし、必要な点を説明しきれないから、これでやったら。
注意 (A)シートにチェックボクスを貼り付けている例のことです。
(B)コントロールツールボックスのチェックボックスの例です。
Sheet3の部分は実状の、チェックボクスを貼り付けているシート名
に変えること。
ーー
べたべた並べないでやろうとすると
Sub test02()
Dim obj
For Each obj In Worksheets("Sheet3").DrawingObjects
' MsgBox obj.Name
If Left(obj.Name, 8) = "CheckBox" Then
' MsgBox obj.Index
obj.Object = False
End If
Next
End Sub
など。
名前をCheckBoxXX以外に変えたりしていると動かないかも。
No.2
- 回答日時:
ちょっと、邪道かも知れませんが・・・。
Private Sub CommandButton1_Click()
On Error GoTo Err_CommandButton1_Click
Dim I As Integer
For I = 1 To 100
ActiveSheet.OLEObjects("CheckBox" & I).Object.Value = 0
Next I
Exit_CommandButton1_Click:
Exit Sub
Err_CommandButton1_Click:
Resume Exit_CommandButton1_Click
End Sub
No.1
- 回答日時:
チェックボックスにも色々あります。
質問文から推察して「ツールバー右クリック」→「コントロールツールボックス」でシートに埋め込んだチェックボックスのことでしょうか?
(その場合デザインモードでCheckBoxを選択すると、数式バーには EMBED("Forms.CheckBox.1","") と表示されます
だとすると、チェックボックスを埋め込んだ「シート名右クリック」→「コードの表示」で開く画面に以下のマクロを貼り付けてください
シートが開かれるたびにチェックボックスのチェックが外れます。
Private Sub Worksheet_Activate()
Dim oObj As OLEObject
For Each oObj In ActiveSheet.OLEObjects
If oObj.progID = "Forms.CheckBox.1" Then
oObj.Object = False
End If
Next oObj
End Sub
ブックを開いたタイミングで1回だけ実行するなら、以下のマクロをThisWorkbookのモジュールシート(VBE画面のVBAプロジェクトでThisWorkbook右クリック→コードの表示で開くモジュールシート)に貼り付けて下さい。3行目のシート名は要修正です。
Private Sub Workbook_Open()
Dim oObj As OLEObject
For Each oObj In Worksheets("Sheet1").OLEObjects 'シート名は要修正
If oObj.progID = "Forms.CheckBox.1" Then
oObj.Object = False
End If
Next
End Sub
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
コマンドボタンがデザインモー...
-
エクセルのVBAで集計をしたい
-
【 Excel】シートの見出しに自...
-
エクセルで複数のSheetを一括フ...
-
VBA シート名を先月の名前に...
-
エクセルを開いたとき常に同じ...
-
マクロで複数シートに条件付き...
-
EXCELでマクロを使わずに図形の...
-
エクセルVBAでcmbBoxのプロパテ...
-
EXCELのエラー
-
メッセージボックスでシート名...
-
エクセル ヘッダー(フッター)...
-
Excelで,特定のシートを開いた...
-
エクセル シート保護をかける...
-
【マクロ】【相談】Excelブック...
-
エクセル・複数のシートを一度...
-
エクセルのチェックボックス
-
エクセル(マクロ)でシートを...
-
エクセルの複数のワークシート...
-
エクセルのマクロについて教え...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
コマンドボタンがデザインモー...
-
エクセルのVBAで集計をしたい
-
【 Excel】シートの見出しに自...
-
【マクロ】【相談】Excelブック...
-
エクセルを開いたとき常に同じ...
-
マクロを複数シートに実行する...
-
EXCELのエラー
-
Excelのマクロの呼び出し元を知...
-
VBAで条件によってシート見出し...
-
マクロを特定の複数シートで実...
-
VBA シート名を先月の名前に...
-
EXCELでマクロを使わずに図形の...
-
エクセルのチェックボックス
-
エクセルでシートの並び替えで...
-
エクセルの複数のワークシート...
-
EXCELでワークシートを開いたら...
-
エクセルで複数のSheetを一括フ...
-
エクセルで、マクロボタンの表...
-
ExcelのSheetに作られたMacro1...
-
エクセル・複数のシートを一度...
おすすめ情報