質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

Q&A

解決済

4回答

875閲覧

Excelで特定のシートを非表示に出来ないようにする方法

moomin_y

総合スコア15

VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

0グッド

0クリップ

投稿2018/11/08 08:09

Excelで特定のシートを非表示に”させない”方法が分かりません。
どなたか、教えていただけませんか。
VBAでこの機能を実現する場合はソースコード、もしくは
参考にできるURLを貼っていただけると助かります。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答4

0

ベストアンサー

ThisWorkbookのイベント処理にこんなのを入れてみるとか。
以下はSheet1が非アクティブになったときに非表示になっていたら再表示させる処理です。

VBA

1Private Sub Workbook_SheetDeactivate(ByVal Sh As Object) 2 If Sh.Name = "Sheet1" And Sh.Visible = False Then 3 Sh.Visible = True 4 End If 5End Sub 6

投稿2018/11/08 08:26

ttyp03

総合スコア16998

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

今回の要件であれば、ttyp03さんたちの回答で動作上全く問題ありませんが、1点気になる点があったため、追加で回答します。

気になる点は「シートの表示・非表示の判定・設定をBooleanで行っていること」です。

Excelのシートの表示状態は、単純な表示・非表示の2種類では無く、3種類あります。
そして、Booleanでは3種類を表現しきれないため、そのための型であるXlSheetVisibilityという列挙型が定義されています。

このことは、Worksheet・Chart・DialogSheet型のVisibleプロパティの定義からも確認できます。

もっとも、通常の表示・非表示にあたるxlSheetVisiblexlSheetHiddenの値は-10、つまりVBAのTrueFalseを整数化した値と一致するのでBooleanを指定しても動作上問題ないのですけれど……。

つまり、以下のように書いた方がより厳密ではないか?ということになります(コード自体はttyp03さんのコードをベースにしています)。

vba

1Private Sub Workbook_SheetDeactivate(ByVal Sh As Object) 2 If Sh.Name = "Sheet1" And Sh.Visible <> xlSheetVisible Then 3 Sh.Visible = xlSheetVisible 4 End If 5End Sub

投稿2018/11/08 14:14

imihito

総合スコア2166

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

imihito

2018/11/09 09:13

本当ですね……。 公式でも両方使っていることは知りませんでした、ありがとうございます。
guest

0

ThisWorkbook モジュールに

VBA

1Private Sub Workbook_SheetDeactivate(ByVal Sh As Object) 2 If Sh.Name = "特定のシート" Then 3 Sh.Visible = True 4 End If 5End Sub

投稿2018/11/08 08:24

iruyas

総合スコア1067

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

https://tonari-it.com/excel-book-protect/#toc1
こちらに記載のあるブックの保護では要件を満たせないでしょうか。

投稿2018/11/08 08:20

ozwind918

総合スコア1140

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問