
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ランキング
-
例外処理のフローチャートの記...
-
Excel2000VBA 複数のテキストボ...
-
VBAで2重のDoLoop関数から抜け...
-
GOSUB命令とは
-
Excel VBAで、ユーザーフォー...
-
AUTOLOADサブルーチンが実行さ...
-
VisualBasicで外サブってできる...
-
モジュールとサブルーチン
-
Attempt to free unreferenced ...
-
モジュール内でのサブルーチン...
-
Excel VBAで、ユーザーフォーム...
-
エクセルVBAでシートモジュール...
-
LCD ディスプレイを Raspberry ...
-
モジュールの最大数はいくつな...
-
モジュールとクラスの違いって...
-
Excel VBAでリンク切れをチェッ...
-
「デバイスは PRN を初期化でき...
-
PythonからPhotoshopスクリプト...
-
Perl モジュールのアンインスト...
-
Wordで、分かち書きをするVBA ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
例外処理のフローチャートの記...
-
Excel VBAで、ユーザーフォー...
-
オフコン(富士通Kシリーズ)...
-
モジュールとサブルーチン
-
COBOLで、Shellを起動するには?
-
ExcelVBA AddinでOnAction
-
初歩的な質問なのですが、サブ...
-
ACCESSのVBAでPrivate Sub ~en...
-
VBAで2重のDoLoop関数から抜け...
-
サブルーチンを使った再帰的な...
-
プログラムの「生産性」について
-
”:”がいっぱいの文について。
-
混合言語のデバッグ(VC++6.0,V...
-
単なる関数の集まりかオブジェ...
-
Attempt to free unreferenced ...
-
サブルーチンを認識しません。
-
requireの使い方がわかりません。
-
Inline CでOpenMPは使えますか?
-
AUTOLOADサブルーチンが実行さ...
-
VisualBasicで外サブってできる...
おすすめ情報