• ベストアンサー

[Excel]保護されたシートのマクロによるオートフィルタ有効設定について

KenKen_SPの回答

  • ベストアンサー
  • KenKen_SP
  • ベストアンサー率62% (785/1258)
回答No.2

> 前回の記事で頂いたセットが、たくさんの機能を含んでおりまして やり過ぎました...すみません。 よくよく考えれば、別にマクロ無効で開かれたところで問題なさそうです。 マクロの無効化対策はカットしましょう。 管理者用のシート一括保護・保護解除は自分の経験上、無いと非常に不便 なので残しておきますが、不要ならプロシージャごとカットして下さい。 メニュー追加コードがあるとどかーんとコードが長くなってしまうのですが、 最近のデジカメはやたらと大きな画像なので、段階的にでもサイズ指定して 画像を挿入できた方が便利だと思いす。で...これも残しておきますね。 前回はろくろくデバッグもしないし、開発用コードも残したままで投稿 してしまったので、細かな修正を何箇所かこっそり入れました。(´・ω・`) 全体を差し替えてみて下さい。長文ごめんなさい。 Option Explicit ' 設定 ------------------------------------------------------------------------ ' シート保護のパスワードを設定(無しなら""とする) Private Const PASSKEY = "123" ' 管理者パスワード(シートの一括保護・解除に使用します) Private Const ADMIN_PASSKEY = "admin" '------------------------------------------------------------------------------ Private WithEvents mApp As Application Private mcMenu     As CommandBarControl Private Sub Workbook_Open()   Dim Sh As Worksheet   On Error Resume Next   If mApp Is Nothing Then Set mApp = Application   Call AddCustomMenu   ’以下の追加コードが今回のご質問の回答になるかと。   Call SheetUnProtect   For Each Sh In ThisWorkbook.Worksheets     Sh.EnableAutoFilter = True   Next   Call SheetProtect   ThisWorkbook.Saved = True End Sub ' // このブック以外ではカスタムメニューを表示させない Private Sub mApp_WindowActivate(ByVal Wb As Workbook, ByVal Wn As Window)   On Error Resume Next   If Not mcMenu Is Nothing Then     If Wb Is ThisWorkbook Then       mcMenu.Visible = True     Else       mcMenu.Visible = False     End If   End If End Sub ' // 管理者メンテ用メニュー Public Sub 管理者専用()   Dim sPass   As String   Dim iErrCount As Integer   Dim iMode   As Variant   On Error Resume Next   Do While iErrCount < 3 ' 3 回までタイプミス OK     sPass = InputBox("Caps キーや Numlock に注意して下さい", _              "管理者パスワード")     If sPass = ADMIN_PASSKEY Then       iMode = InputBox("1: 全シート保護" & vbLf _               & "2: 全シート保護解除", _                "管理者メニュー")       If Val(iMode) = 2 Then         Call SheetUnProtect         MsgBox "シート保護解除しました", vbInformation       Else         Call SheetProtect         MsgBox "シート保護しました", vbInformation       End If       Exit Sub     Else       Call SheetProtect       iErrCount = iErrCount + 1     End If   Loop   MsgBox "認証に失敗しました", vbCritical End Sub ' // マクロで画像を挿入 Private Sub InsertPic()   Dim vFnames As Variant   Dim vFname As Variant   Dim sngZoom As Single   Dim Pic   As Picture   Dim sngW  As Single   Dim sngH  As Single   Dim iOffet As Integer   On Error Resume Next   vFnames = Application.GetOpenFilename( _        FileFilter:="Image ファイル, *.jpg;*.bmp;*.gif;*.tif;*.png", _        Title:="画像ファイルを指定して下さい", _        MultiSelect:=True)   If IsArray(vFnames) Then     Application.ScreenUpdating = False     With Selection       sngW = .Width: sngH = .Height     End With     sngZoom = CSng(Application.CommandBars.ActionControl.Parameter)     iOffet = 0     For Each vFname In vFnames       Set Pic = ActiveSheet.Pictures.Insert(vFname)       With Pic         .Placement = xlFreeFloating         .Locked = False       End With       With Pic.ShapeRange         .LockAspectRatio = msoTrue         Select Case sngZoom           Case 0: .Height = sngH           Case 1: .Width = sngW           Case 2: .LockAspectRatio = msoFalse               .Width = sngW               .Height = sngH           Case 10 To 400 ' 10~400% を有効とする               .Height = .Height * sngZoom / 100#         End Select         ' MultiSelect 時のオフセット         .IncrementTop CSng(10 * iOffet)         .IncrementLeft CSng(10 * iOffet)         iOffet = iOffet + 1       End With       Set Pic = Nothing     Next   End If End Sub ' // セルの右クリックメニューにカスタムメニューを追加 Private Sub AddCustomMenu()   Dim Cmb   As CommandBar   Dim sAction As String   Set Cmb = Application.CommandBars("Cell")   On Error Resume Next   Cmb.Controls("画像の挿入(&D)").Delete   Set mcMenu = Cmb.Controls.Add(Type:=msoControlPopup, Temporary:=True)   With mcMenu     .Caption = "画像の挿入(&D)"     .BeginGroup = True     sAction = ThisWorkbook.FullName & "!ThisWorkbook.InsertPic"     With .Controls.Add(Type:=msoControlButton)       .Caption = "選択範囲の縦を基準にする(&1)"       .OnAction = sAction       .Parameter = 0     End With     With .Controls.Add(Type:=msoControlButton)       .Caption = "選択範囲の幅を基準にする(&2)"       .OnAction = sAction       .Parameter = 1     End With     With .Controls.Add(Type:=msoControlButton)       .Caption = "選択範囲の縦横に合わせる(&3)"       .OnAction = sAction       .Parameter = 2     End With     With .Controls.Add(Type:=msoControlButton)       .Caption = "100%(&4)"       .OnAction = sAction       .Parameter = 100     End With     With .Controls.Add(Type:=msoControlButton)       .Caption = "75%縮小(&5)"       .OnAction = sAction       .Parameter = 75     End With     With .Controls.Add(Type:=msoControlButton)       .Caption = "50%縮小(&6)"       .OnAction = sAction       .Parameter = 50     End With     With .Controls.Add(Type:=msoControlButton)       .Caption = "25%縮小(&7)"       .OnAction = sAction       .Parameter = 25     End With   End With   Set Cmb = Nothing   If mApp Is Nothing Then Set mApp = Application   On Error GoTo 0 End Sub ' // シートに対しパス付き保護をかけます Private Sub SheetProtect(Optional ByRef Wst As Worksheet)   ' 引数:[Wst] シートオブジェクト。省略するとブック内の全シート   Dim Sh As Worksheet   On Error Resume Next   If Not Wst Is Nothing Then       Wst.Protect Password:=PASSKEY, _             UserInterfaceOnly:=True, _             DrawingObjects:=False   Else     For Each Sh In ThisWorkbook.Worksheets       Sh.Protect Password:=PASSKEY, _             UserInterfaceOnly:=True, _             DrawingObjects:=False     Next   End If End Sub ' // シートの保護を解除します Private Sub SheetUnProtect(Optional ByRef Wst As Worksheet)   ' 引数:[Wst] シートオブジェクト。省略するとブック内の全シート   Dim Sh As Worksheet   On Error Resume Next   If Not Wst Is Nothing Then       Wst.Unprotect Password:=PASSKEY   Else     For Each Sh In ThisWorkbook.Worksheets       Sh.Unprotect Password:=PASSKEY     Next   End If End Sub

ele_ele
質問者

お礼

前記事に続きましてのご回答、誠にありがとうございます。 再導入に手間取ってしまい、半日ほど掛かってしまいましたが、 先ほど無事全ての機能が動作する事を確認できました。 管理者用の一括機能や、画像の縮小選択などは大変重宝を させて頂いております。 近日中に実業務で導入する運びとなりました事をご報告させて 頂くとともに、改めてお礼を申し上げます。

関連するQ&A

  • [EXCEL]保護されたシートでオートフィルタ利用可能にしたいのですが

    いかのURLにも同じような質問があり、 http://oshiete1.goo.ne.jp/qa2550996.html それにしたがって、シート保護でもオートフィルタ可能にするための VBA記述を行いましたが、オートフィルタが利用可能になりません。 シートの保護はできているようですし、エラーもでません。 記述したコードは以下になります。 Sub Workbook_Open()   Dim Sh As Worksheet   For Each Sh In Worksheets    Sh.Unprotect Password:="fukuri"    Sh.EnableAutoFilter = True    Sh.Protect Password:="fukuri", userInterfaceOnly:=True   Next Sh End Sub なにか、不足している記述があるのでしょうか? もし、わかる方がいらっしゃったら是非アドバイスいただけないでしょうか? 私自身、VBAを利用するのがはじめてで勉強不足にもかかわらず 大変恐縮ですが、ご回答いただければ幸いです。 宜しくお願いいたします。

  • エクセル保護でのグループ化、フィルタの使用方法

    エクセル2007でセルの保護の状態でグループ化の表示切替とオートフィルタを使用する方法を教えてください。 現在ファイル内で特定の列に保護をかけています。 保護により無効となってしまったグループかの表示・非表示はVBAで 切替られるようにしました。 Private Sub Workbook_Open() With Worksheets("シート名") .EnableOutlining = True .Protect UserInterfaceOnly:=True End With End Sub 更に、オートフィルタを使用したいのですが、 保護を行う時に「オートフィルタの使用」にチェックを入れているのに 選択が不可能な状態です。 すべての条件を満たすにはどのような方法があるのでしょうか。 お分かりになる方がいられましたらご教授ください。

  • Excel2003でシート保護(オートフィルタ使用にはチェック)するとオートフィルタが使えない

    Excel2003を使用しています。 シートの保護でオートフィルタの使用にチェックを入れて保護をかけた後、データ - フィルタ - オートフィルタ が灰色に表示され、使用出来ません。 フィルタ設定 → シート保護だとオートフィルタを使用できます。 Excelの試用でオートフィルタの使用にチェックを入れて保護をかけても、保護後にはオートフィルタの設定は出来ないのでしょうか?

  • Excelのオートフィルタ→シート保護→共有について

    Excel2000のブックを所内で共有で使用するのに 下記サイトのマクロを入力しました。 http://kiyopon.sakura.ne.jp/situmon/index.htm Private Sub Workbook_Open() Dim Sh As Worksheet For Each Sh In Worksheets Sh.EnableAutoFilter = True Sh.Protect UserInterfaceOnly:=True Next Sh End Sub 入力後ブックの共有を行い、一度閉じて 再度ファイルを開くと 実行時エラー'1004':'Protect'メソッドは失敗しました:Worksheet'オブジェクト とメッセージが出ます。 共有にすることにより、このメッセージが出ると思われますが、 恥ずかしながらマクロの事は全く分かりません。 ご教授よろしくお願い致します。

  • Auto_Openマクロ

    Excel2003のマクロで、 Sub Auto_Open() ActiveSheet.DisplayAutomaticPageBreaks = True End Sub としているのですが、起動時に開くシートにしか適用されません。 ページが増えていくのでブック内の全シートに適用するにはどうしたらいいでしょうか?

  • エクセルVBA 保護シート&フィルタ実行 全シート

    VBA超初心者です。 たくさんのシートのあるエクセルで、 シート保護後もフィルタを使用できるようにVBAを設定したいと思ってます。 (現在エクセル2000を使用してます) ネットで調べてVBAを設定してみました。 しかし下記のようにするとコンパイルエラーになってしまうのですが、 正しい方法を教えていただけると助かります。 Option Explicit Private Sub Workbook_BeforeClose(Cancel As Boolean)   Application.CommandBars("Cell").Reset End Sub Private Sub Workbook_Open()   With Application.CommandBars("Cell").Controls.Add( _            Type:=msoControlButton, Before:=1, Temporary:=True)     .Caption = "AutoFilter"     .OnAction = "ThisWorkbook.filter"   End With   With Worksheets.Select     .Unprotect     .EnableAutoFilter = True     .Protect UserInterfaceOnly:=True   End With End Sub Private Sub filter()   On Error Resume Next   Selection.AutoFilter End Sub

  • オートフィルタがかかっていて、なおかつ抽出中なら

    オートフィルタがかかっていて、なおかつ抽出中なら、 という状態をvbaで取得する方法はありますか? Sub Sample() If ActiveSheet.AutoFilterMode = True Then End If End Sub これだと、 オートフィルタがかかっているだけでも、反応してしまいます。 「行番号が青色になってるのなら」 と同じ状態にしたいのですが、 どういうコードになりますか?

  • Excel2003オートフィルタの有無を確認マクロ

    オートフィルタを設定するときは、 Selection.AutoFilter を使ってもできますが、これですとオートフィルタがオン・オフどちらの状態かわかりません。 これを、オートフィルタをオンにしますよ、オフにしますよ、という命令を送るように命令を一行 で書くことは可能なのでしょうか? もし手順で書くなら(http://www.asahi-net.or.jp/~zn3y-ngi/YNxv208.html)から引用しますが、 次のようにできるようです。 /-------------------------------------------/ Private Sub オートフィルタの状態を調べて切り替える() If Worksheets("SSS").AutoFilterMode Then 'オートフィルタモードなら MsgBox "オートフィルタは現在オンです。[OK]ボタンをクリックするとオフにします" オートフィルタのオンオフを切り替える Else MsgBox "オートフィルタは現在オフです。[OK]ボタンをクリックするとオンにします" オートフィルタのオンオフを切り替える End If End Sub

  • [Excel2000]auto_closeを止めさせるには

    Excel2000で、 特定のボタンを押した場合以外の閉じる処理を キャンセルさせたいのですがうまくいきません sub ボタン押() flg = true end sub sub auto_close() if flg <> true then msgbox "AAA" exit sub end if end sub これでは、どーやってもそのまま終了してしまいます。 なにか良い方法はないでしょうか・・・ よろしくおねがいします。

  • シートを保護した状態で2つのシートでオートフィルタを使う方法

    Excel2000です。 シートを保護した状態でオートフィルタを使用する方法を教えてください。 シートはA,B,C,D,Eの5つあり、その内のAとBのみオートフィルタを使用したいのですが。