ここから本文です

エクセル VBA ほぼ初心者です

kat********さん

2012/4/2314:09:16

エクセル VBA ほぼ初心者です

テキストボックスに数値とマイナスだけを入力できるように作りました。

Sub TextBox1_KeyPress(ByVal KeyAscii As MSForms.ReturnInteger)

If KeyAscii = 45 Then
If TextBox1.Value = "" Then
TextBox1.Value = "-"
ElseIf TextBox1.Value = "-" Then
TextBox1.Value = ""
Else
TextBox1.Value = Val(TextBox1.Value) * (-1)
End If
KeyAscii = 0
ElseIf KeyAscii < 45 Or _
KeyAscii = 47 Or _
KeyAscii > 57 Then
KeyAscii = 0
ElseIf KeyAscii = 46 And TextBox1.Value Like "*.*" Then
KeyAscii = 0
End If
End Sub

そのとき小数点第3位までしか入力できないようにするにはどのようにプログラムを作ればいいのでしょうか?

閲覧数:
1,198
回答数:
1
お礼:
500枚

違反報告

ベストアンサーに選ばれた回答

kyo********さん

2012/4/2315:25:22

● ユーザーフォーム・テキストボックスの入力制限

以下のようになります。
応用してみて下さい。
********************************************************
Private Sub TextBox1_Change()
If TextBox1.Text = "-" Then Exit Sub
If Not IsNumeric(TextBox1.Text) Then TextBox1.Text = ""
If Val(Format(TextBox1.Text, "#")) - Val(TextBox1.Text) _
<> 0 Then TextBox1.Text = Format(TextBox1.Text, "#.###")
End Sub
********************************************************

質問した人からのコメント

2012/4/23 16:27:31

降参 ありがとうございます。なんとかできそうかもです^^

みんなで作る知恵袋 悩みや疑問、なんでも気軽にきいちゃおう!

Q&Aをキーワードで検索:

Yahoo! JAPANは、回答に記載された内容の信ぴょう性、正確性を保証しておりません。
お客様自身の責任と判断で、ご利用ください。
本文はここまでです このページの先頭へ

「追加する」ボタンを押してください。

閉じる

※知恵コレクションに追加された質問は選択されたID/ニックネームのMy知恵袋で確認できます。

不適切な投稿でないことを報告しました。

閉じる