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

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

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

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

マクロ

定義された処理手続きに応じて、どのような一連の処理を行うのかを特定させるルールをマクロと呼びます。

Q&A

解決済

1回答

5161閲覧

UserForm1.Showのエラー

yuyu36

総合スコア3

VBA

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

マクロ

定義された処理手続きに応じて、どのような一連の処理を行うのかを特定させるルールをマクロと呼びます。

0グッド

0クリップ

投稿2022/01/03 15:47

前提・実現したいこと

標準モジュールで「シート1」のコマンドボタンからユーザフォームを起動して、「シート2」「シート4」からデータをリストボックスに反映して、リストボックスから選択したものを、「シート1」に転記するマクロを作成中。
ユーザフォームを起動する標準モジュールがうまく作動せず、以下のエラーメッセージが発生しました。

発生している問題・エラーメッセージ

なぜか「シート4」でしかユーザーフォームが起動してくれない。
実行時エラー’1004’:
アプリケーション定義またはオブジェクト定義のエラー

Option Explicit Sub ボタン1_Click() UserForm1.Show vbModeless End Sub ↑標準モジュール ↓ユーザーフォーム Option Explicit Dim TextRow As Long Dim i As Long Dim h As Long Dim LastRow As Long Private Sub CommandButton2_Click() Unload Me End Sub Private Sub ListBox1_Change() ListBox2.Clear With Worksheets("Sheet2") Select Case ListBox1 Case ListBox1.List(0) ListBox2.List = .Range("C4:C20").Value Case ListBox1.List(1) ListBox2.List = .Range("D4:D20").Value Case ListBox1.List(2) ListBox2.List = .Range("E4:E20").Value End Select End With With UserForm1.ListBox2 ' 複数選択可 .MultiSelect = fmMultiSelectMulti End With End Sub Private Sub UserForm_Initialize() With Worksheets("Sheet4") 'セル範囲のデータをリストボックスに表示 ListBox1.List = .Range(Cells(3, 3), Cells(20, 3)).Value End With End Sub Private Sub CommandButton1_Click() 'テクストボックスに入力された値から+2行の位置に入力 TextRow = UserForm1.TextBox1 + 2 For i = 0 To ListBox2.ListCount - 1 If ListBox2.Selected(i) Then With Worksheets("Sheet1") 'セルへ転記 .Cells(TextRow, 6) = ListBox2.List(i) TextRow = TextRow + 1 End With End If Next End Sub エクセル VBA ソースコード

試したこと

UserForm_Initialize()のプロシージャを消去すると、UserForm1.Showが作動してくれる

エクセル2016
ここにより詳細な情報を記載してください。

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

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

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

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

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

guest

回答1

0

ベストアンサー

定番のFAQですね。

vba

1Private Sub UserForm_Initialize() 2 3 With Worksheets("Sheet4") 4 5 'セル範囲のデータをリストボックスに表示 6' ListBox1.List = .Range(Cells(3, 3), Cells(20, 3)).Value 7 ListBox1.List = .Range(.Cells(3, 3), .Cells(20, 3)).Value 8 End With 9 10End Sub

.Range(Cells(3, 3), Cells(20, 3)).Valueだと、
Worksheets("Sheet4").Range(ActiveSheet.Cells(3, 3), ActiveSheet.Cells(20, 3)).Valueという意味になり、Sheet4がアクティブでないと、Rangeの外と中で別のシートを指定することになりエラーになります。

投稿2022/01/04 02:11

hatena19

総合スコア33699

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

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

yuyu36

2022/01/04 03:23

ありがとうございました。このような動作になること勉強になりました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問