LoginSignup
4
1

More than 5 years have passed since last update.

【VBA】入力規則(Validation)の1004について

Posted at

ハマってかなり時間を取られたので、忘れないようにメモ。

すでに入力規則が設定されているセルについて、
今設定されている入力規則を破棄し、新たな入力規則を設定しようとしたところ、
.Addの行で
「1004:アプリケーション定義またはオブジェクト定義のエラーです」
が発生。
ググったりした結果、どうやら実行前に対象のセルをSelectしてからすると出なくなると多数。
…ですがやはりうまくいかず。

Cells(7, 8).Select
With Selection.Validation
    .Delete
    .Add Type:=xlValidateList, _
        AlertStyle:=xlValidAlertStop, _
        Operator:=xlBetween, _
        Formula1:="=プルダウンリスト"
    .IgnoreBlank = True
    .InCellDropdown = True
    .InputTitle = ""
    .ErrorTitle = ""
    .InputMessage = ""
    .ErrorMessage = ""
    .IMEMode = xlIMEModeNoControl
    .ShowInput = True
    .ShowError = False
End With

【結果】
今回の件、入力規則を再設定する対象のシートが保護されていることが問題でした。
ググったときにもシート保護してるとうまくいかないかもというのは見かけていましたが、
自分は、シート保護下でもマクロの処理だけは可能な

ActiveSheet.Protect UserInterfaceOnly:=True, Password:="XXXXX"

を使用していて、その問題はこれで大丈夫だろうと…

コイツが原因でした。

これを処理の最初にシートの保護解除・最後に保護をかけ直すことで解決できました。

ActiveSheet.Unprotect Password:="XXXXX"

    ~ 処理 ~

ActiveSheet.Protect Password:="XXXXX"
4
1
1

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
4
1