
Excel2000のVBAでユーザーフォームを使って簡単なインターフェースを作っています。
今まではほとんど IF~Then 文のみでどうにかなるよう処理をしてきましたが、今回はさすがにコードが長くなってしまうので何とかしたいと思い質問させていただきました。
現在
TextBox1.Value = ""
TextBox2.Value = ""
TextBox3.Value = ""
…
TextBox50.Value = ""
のような処理になっています。
こういった処理が複数回あり、コードが長くなってしまっています。
これを簡素化する方法はないでしょうか?
No.3ベストアンサー
- 回答日時:
こんにちは。
単に、以下のような単独のプロシージャーか、サブルーチン化させるなら、同じUserformモジュールにしたらいかがですか?
Private Sub CommandButton1_Click()
For i = 1 To 50
Me.Controls("TextBox" & CStr(i)).Value = ""
Next
End Sub
'--------------------------------
'または、
Private Sub CommandButton1_Click()
Call s_TextBoxesClear
End Sub
Sub s_TextBoxesClear()
For i = 1 To 50
Me.Controls("TextBox" & CStr(i)).Value = ""
Next
End Sub
もちろん、Userformが複数あるなら、標準モジュールを使うべきかもしれませんが。
回答ありがとうございました。
今回はコードの記述を簡素化したかったので、上の方法で解決できました。
For~Nextを使うところまでは推察できていたのですが、CStrを知りませんでした。これで一つお利口になれましたw
No.2
- 回答日時:
失礼・・・。
わざわざオブジェクトに入れる必要ありません^^;(しかもObject型つかっちゃってるし・・・)【UserForm1】
Private Sub UserForm_Click()
Call TextInitialize(Me)
End Sub
【Module1】
Public Sub TextInitialize(ByRef Frm As UserForm)
Const CtrlName As String = "TextBox"
Const CtrlStIdx As Long = 1
Const CtrlEdIdx As Long = 50
Dim i As Long
For i = CtrlStIdx To CtrlEdIdx
Frm.Controls(CtrlName & CStr(i)).Text = ""
Next
End Sub
他にもミスしてそう・・・(笑)
No.1
- 回答日時:
> こういった処理が複数回あり、コードが長くなってしまっています。
複数回あるのであれば、この部分だけサブルーチン化してしまえば良いと思います。
以下は例です。
【UserForm1】
Private Sub UserForm_Click()
Call TextInitialize(Me)
End Sub
【Module1】
Public Sub TextInitialize(ByRef Frm As UserForm)
Const CtrlName As String = "TextBox"
Const CtrlStIdx As Long = 1
Const CtrlEdIdx As Long = 50
Dim Obj As Object
Dim i As Long
For i = CtrlStIdx To CtrlEdIdx
Set Obj = Frm.Controls(CtrlName & CStr(i))
Obj.Text = ""
Next
End Sub
早速の回答ありがとうございました。
こんなに早く回答がくるとは思っていませんでした。
今回はとりあえず簡単そうな方法でやってみることにします。
行き当たりばったりで作っているので、苦労してますが、今後必要に応じてサブルーチン化も検討したいと思います。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) VBA Userformで一部別シートに転記がしたいのですが 2 2023/05/24 13:08
- Visual Basic(VBA) VBA 重複チェック後に値をワークシートに転記する方法を教えてください。 1 2023/03/19 12:43
- Visual Basic(VBA) エクセル VBAで複数セル選択時エラーになる問題 3 2022/10/04 02:40
- Visual Basic(VBA) VBAでのループ順序について 3 2023/03/13 10:55
- Excel(エクセル) Excel VBAどこが間違ってますか? 4 2023/07/17 10:04
- Excel(エクセル) なぜExit Subがあるのかわかりません 4 2023/02/19 12:34
- Visual Basic(VBA) 動きっぱなしです。止め方とプロシージャの間違いを教えて下さい! 5 2022/08/15 23:08
- JavaScript javascriptのちょっとした動作不良(原因は突き止めたのですが) 1 2023/06/15 19:58
- Excel(エクセル) Excelのtextboxへの入力で小数点以下に0が続く場合でも正しく表示したい 3 2022/04/11 13:53
- Visual Basic(VBA) VBAコードを張り付け後のエクセルの進め方 2 2023/02/07 18:24
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・一番好きなみそ汁の具材は?
- ・泣きながら食べたご飯の思い出
- ・「これはヤバかったな」という遅刻エピソード
- ・初めて自分の家と他人の家が違う、と意識した時
- ・いちばん失敗した人決定戦
- ・思い出すきっかけは 音楽?におい?景色?
- ・あなたなりのストレス発散方法を教えてください!
- ・もし10億円当たったら何に使いますか?
- ・何回やってもうまくいかないことは?
- ・今年はじめたいことは?
- ・あなたの人生で一番ピンチに陥った瞬間は?
- ・初めて見た映画を教えてください!
- ・今の日本に期待することはなんですか?
- ・集中するためにやっていること
- ・テレビやラジオに出たことがある人、いますか?
- ・【お題】斜め上を行くスキー場にありがちなこと
- ・人生でいちばんスベッた瞬間
- ・コーピングについて教えてください
- ・あなたの「プチ贅沢」はなんですか?
- ・コンビニでおにぎりを買うときのスタメンはどの具?
- ・おすすめの美術館・博物館、教えてください!
- ・【お題】大変な警告
- ・洋服何着持ってますか?
- ・みんなの【マイ・ベスト積読2024】を教えてください。
- ・「これいらなくない?」という慣習、教えてください
- ・今から楽しみな予定はありますか?
- ・AIツールの活用方法を教えて
- ・最強の防寒、あったか術を教えてください!
- ・歳とったな〜〜と思ったことは?
- ・モテ期を経験した方いらっしゃいますか?
- ・好きな人を振り向かせるためにしたこと
- ・スマホに会話を聞かれているな!?と思ったことありますか?
- ・それもChatGPT!?と驚いた使用方法を教えてください
- ・見学に行くとしたら【天国】と【地獄】どっち?
- ・これまでで一番「情けなかったとき」はいつですか?
- ・この人頭いいなと思ったエピソード
- ・あなたの「必」の書き順を教えてください
- ・14歳の自分に衝撃の事実を告げてください
- ・人生最悪の忘れ物
- ・あなたの習慣について教えてください!!
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
例外処理のフローチャートの記...
-
Matlabのinline関数
-
サブルーチンに引数を2つ以上...
-
初歩的な質問なのですが、サブ...
-
Excel VBAで、ユーザーフォー...
-
perlの構文でカンマの意味が分...
-
Excel VBAでリンク切れをチェッ...
-
エクセルVBAでシートモジュール...
-
「デバイスは PRN を初期化でき...
-
Excel VBA 『Call』で呼び出す...
-
Excel VBAで、ユーザーフォーム...
-
vba userFormのSubを標準モジュ...
-
ExcelでTelnetを動かしたい
-
Perl モジュールのアンインスト...
-
教えて下さい。
-
VBSがコンパイルエラーになりま...
-
vba 標準モジュールインポート...
-
ユーザー定義関数に#NAME?が返...
-
Access VBA標準モジュールにつ...
-
プロキシ経由でjavamailを使っ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
例外処理のフローチャートの記...
-
Excel VBAで、ユーザーフォー...
-
モジュールとサブルーチン
-
COBOLで、Shellを起動するには?
-
オフコン(富士通Kシリーズ)...
-
”:”がいっぱいの文について。
-
GOSUB命令とは
-
VBAで2重のDoLoop関数から抜け...
-
ACCESSのVBAでPrivate Sub ~en...
-
ExcelVBA AddinでOnAction
-
サブルーチンを認識しません。
-
perlの構文でカンマの意味が分...
-
サブルーチンやif分以外での中括弧
-
サブルーチンに引数を2つ以上...
-
配列と互換性のない型の要素に...
-
Perlのスレッド?
-
cobol サブルーチンのlink
-
プログラムの「生産性」について
-
初歩的な質問なのですが、サブ...
-
smallbasic について教えてくだ...
おすすめ情報