金額を入力して計算するルーチンを作成しています。
以下のコードで、数字以外は入力不可にしたのですが・・・・
数値を訂正するためのBack Spaceも入力できなくて困っています。
0~9までしか受け付けないコードなのはわかっていますが、それに加えてBack Spaceも受け付けられるようにするにはどんなコードを書けばよいでしょうか。
Private Sub genkin_KeyPress(KeyAscii As Integer)
If KeyAscii >= Asc("0") And KeyAscii <= Asc("9") Then Exit Sub
Else
KeyAscii = 0
Beep
End If
End Sub
No.2ベストアンサー
- 回答日時:
どもども田吾作7です
>If KeyAscii >= Asc("0") And KeyAscii <= Asc("9") Then Exit Sub
ここの意味を理解されてますでしょうか?
これはパラメータのKeyAsciiの入力制限を行っております。
Asc(0)は48です。Asc("9")は57です。
まずそれはそれでおいといて、、、
プレスイベントのコードをコメントして、
Debug.Print KeyAscii
と書いて文字入力してみてください。
イミディエイトウィンドウに、入力された文字コードが出力されます。
同時に[BackSpace]が8という値が得ることもわかると思います。
ですのでプレスイベントは、次のようになります。
If KeyAscii >= Asc(0) And KeyAscii <= Asc(9) Then Exit Sub
If KeyAscii = 8 Then Exit Sub
KeyAscii = 0
Beep
これは参考までなのですが・・・
Microsoft Masked Edit Controlというのをご存知ですか?
メニューバーの[プロジェクト][コンポーネント]の中に存在しています。
これを使用すると、数値、日付など、入力制限を行うことの出来ます。
でわでわ
ありがとうございます。 もう初心者には何が何だか・・・ の世界で本当に助かります。 Microsoft Masked Edit Control を早速フォームに乗せてみました。 こんな便利なコントロールがあるなんて、「そんなん知ら~ん!」って感じでした。
No.1
- 回答日時:
手元にVisual Basicがないので、確認はしていませんが
以下のコードではダメなのでしょうか?
Private Sub genkin_KeyPress(KeyAscii As Integer)
If(KeyAscii >= Asc("0") And (KeyAscii <= Asc("1")) _
Or KeyAscii <> Asc(バックスペースの番号) Then
Exit Sub
Else
KeyAscii = 0
Beep
End If
End Sub
これではだめなのでしょうか?
ではでは☆
この回答への補足
or でつなぐとなぜかどんなキーでも受け付けてしまいます。
なぜでしょうか・・・ 何度試してもだめなんですよね。
どこかコードがまちがっているのかなぁ・・・
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・14歳の自分に衝撃の事実を告げてください
- ・架空の映画のネタバレレビュー
- ・「お昼の放送」の思い出
- ・昨日見た夢を教えて下さい
- ・ちょっと先の未来クイズ第4問
- ・【大喜利】【投稿~10/21(月)】買ったばかりの自転車を分解してひと言
- ・メモのコツを教えてください!
- ・CDの保有枚数を教えてください
- ・ホテルを選ぶとき、これだけは譲れない条件TOP3は?
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・【コナン30周年】嘘でしょ!?と思った○○周年を教えて【ハルヒ20周年】
- ・ハマっている「お菓子」を教えて!
- ・最近、いつ泣きましたか?
- ・夏が終わったと感じる瞬間って、どんな時?
- ・10秒目をつむったら…
- ・人生のプチ美学を教えてください!!
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・都道府県穴埋めゲーム
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Excel-VBAでInputBox+Pulldown...
-
初歩的な事だと思います。 Sub...
-
エクセルVBA テキストボックス...
-
テキストボックスの番号を使っ...
-
教えて!全角文字「μ」の半角
-
「イ分」・・・フンという文字...
-
EXCEL VBAで、URLを入力して、...
-
アクセスのマクロ
-
DataGridView 列ごとの入力制限
-
EXCEL VBA で指定した範囲に入...
-
HTMLで全角文字のみ入力するに...
-
エディットボックスの入力制限...
-
複数行の入力を受け取る方法
-
数字以外の入力をエラーにする...
-
VBA R1C1形式で変数の入力について
-
InputBoxからの掛け算
-
Vba テキストボックスでボック...
-
「ゔ」をHTMLで記述したい
-
アルファベットGの小文字の入力
-
入力フォームの値をQRコードで...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセルVBA テキストボックス...
-
テキストボックスの番号を使っ...
-
初歩的な事だと思います。 Sub...
-
Excel-VBAでInputBox+Pulldown...
-
「イ分」・・・フンという文字...
-
excel vba でユーザーフォーム...
-
VBAでInputBoxの再入力をさせる...
-
アクセスのマクロ
-
エディットボックスの入力制限...
-
数字以外の入力をエラーにする...
-
教えて!全角文字「μ」の半角
-
ExcelVBAのユーザーフォームで...
-
EXCEL VBA で指定した範囲に入...
-
アルファベットGの小文字の入力
-
VBA R1C1形式で変数の入力について
-
TextBoxから数字が文字...
-
入力フォームの値をQRコードで...
-
DataGridView 列ごとの入力制限
-
DataGridViewの桁数制限に関して
-
accessで該当するレコードがな...
おすすめ情報