Excelで特殊文字の入力を防ぐにはどうすればよいですか?
特定の場合、セルには文字や数字のみを入力し、@#$%&などの特殊文字の入力を防ぎたい場合があります。Excelには、値を挿入する際に特殊文字の入力を防ぐ機能はありますか?
Kutools for Excelを使用して特殊文字の入力を防ぐ
データの検証を使用して特殊文字の入力を防ぐ
Excelのデータ検証機能を使用すると、英数字のみを入力できるように制限できます。以下の手順に従ってください:
1. 特殊文字の入力を防ぎたい範囲を選択します。
2. 次に、[データ] > [データの検証] > [データの検証] をクリックします。スクリーンショットをご覧ください:
3. [データの検証] ダイアログボックスで、[設定] タブをクリックし、[許可] のドロップダウンリストから [カスタム] を選択します。その後、次の数式を 数式テキストボックスに入力します:=ISNUMBER(SUMPRODUCT(SEARCH(MID(A1,ROW(INDIRECT("1:"&LEN(A1))),1),"0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ")))。スクリーンショットをご覧ください:
注: A1 は選択した範囲の最初のセル(左から右)を示します。
4. そして、[OK] をクリックしてダイアログを閉じます。これで、指定した列(オプションを適用した場所)に特殊文字を含む値を入力しようとすると、次の警告メッセージが表示されます。
VBAコードを使用して特殊文字の入力を防ぐ
次のVBAコードを使用しても、テキスト値を入力する際に特殊文字を防ぐことができます。
1. ALT + F11 キーを押しながら押すと、Microsoft Visual Basic for Applications ウィンドウが開きます。
2. 左側のプロジェクトエクスプローラーから使用しているワークシートを選択し、ダブルクリックしてモジュールを開き、次のVBAコードを空白の モジュールにコピーして貼り付けます:
VBAコード:Excelでの特殊文字の入力を防ぐ
Private Const FCheckRgAddress As String = "A1:A100"
Private Sub Worksheet_Change(ByVal Target As Range)
'Update 20140905
Dim xChanged As Range
Dim xRg As Range
Dim xString As String
Dim sErrors As String
Dim xRegExp As Variant
Dim xHasErr As Boolean
Set xChanged = Application.Intersect(Range(FCheckRgAddress), Target)
If xChanged Is Nothing Then Exit Sub
Set xRegExp = CreateObject("VBScript.RegExp")
xRegExp.Global = True
xRegExp.IgnoreCase = True
xRegExp.Pattern = "[^0-9a-z]"
For Each xRg In xChanged
If xRegExp.Test(xRg.Value) Then
xHasErr = True
Application.EnableEvents = False
xRg.ClearContents
Application.EnableEvents = True
End If
Next
If xHasErr Then MsgBox "These cells had invalid entries and have been cleared:"
End Sub
注: 上記のコードでは、Private Const FCheckRgAddress As String = "A1:A100" スクリプトの範囲 A1:A100 を、特殊文字を防ぎたい独自の範囲に変更できます。
3. その後、このコードを保存して閉じます。これで、範囲 A1:A100 に特殊文字を含むテキスト値を入力すると、その入力は即座に消去され、次の警告メッセージが表示されます。
Kutools for Excelを使用して特殊文字の入力を防ぐ
実際、Kutools for Excel -- 便利で多機能なツールがある場合、その入力を制限する機能を使用することで、簡単に選択範囲での特殊文字の入力を防ぐことができます。
Kutools for Excelをインストール後、以下のように操作してください:
1. 特殊文字の入力を防ぎたい範囲を選択し、 Kutools > 入力を制限する > 入力を制限するをクリックします。スクリーンショットをご覧ください:
2. 入力を制限する ダイアログで、 特殊文字の入力を制限する オプションをチェックします。スクリーンショットをご覧ください:
3. OKをクリックすると、このユーティリティを適用するとデータ検証が削除される旨のダイアログが表示されますので、 はい をクリックして次のダイアログに進みます。このユーティリティがセクションで動作していることを通知されます。スクリーンショットをご覧ください:
4. OK をクリックしてダイアログを閉じます。これ以降、選択範囲に特殊文字を入力しようとすると警告ダイアログが表示されます。
Kutools for Excel - 必要なツールを300以上搭載し、Excelの機能を大幅に強化します。永久に無料で利用できるAI機能もお楽しみください!今すぐ入手
デモ:Kutools for Excelを使用して特殊文字の入力を防ぐ
関連記事:
Excelでスペースを含む値の入力を防ぐにはどうすればよいですか?
Excelで列内の重複エントリを防ぐにはどうすればよいですか?
最高のオフィス生産性ツール
🤖 | Kutools AI アシスタント: データ分析を革命化する: インテリジェント実行 | コード生成 | カスタム数式の作成 | データを分析しグラフを生成 | 拡張機能を呼び出す… |
人気の機能: 重複を見つけてハイライトまたはマーキング | 空白行を削除 | データを失わずに列またはセルを統合 | 丸める ... | |
スーパーLOOKUP: 複数条件のVLookup | 複数値のVLookup | 複数シートの検索 | ファジーマッチ .... | |
高度なドロップダウンリスト: ドロップダウンリストを迅速に作成 | 依存ドロップダウンリスト | マルチセレクトドロップダウンリスト .... | |
列管理: 特定の数の列を追加 | 列を移動 | 非表示列の可視ステータスを切り替え | 範囲と列を比較 ... | |
注目の機能: グリッドフォーカス | デザインビュー | 強化された数式バー | ワークブック & ワークシート管理 | オートテキスト ライブラリ (Auto Text) | 日付ピッカー | データの統合 | セルの暗号化/復号化 | リストで電子メールを送信 | スーパーフィルター | 特殊フィルタ (太字/斜体/取り消し線をフィルタリング...) ... | |
トップ15のツールセット: 12 のテキストツール (テキストの追加, 特定の文字を削除, ...) | 50以上 のグラフ の種類 (ガントチャート, ...) | 40以上の実用的な 数式 (誕生日に基づいて年齢を計算する, ...) | 19 の挿入ツール (QRコードの挿入, パスから画像を挿入, ...) | 12 の変換ツール (単語に変換する, 通貨変換, ...) | 7 の統合 & セルの分割ツール (高度な行のマージ, セルの分割, ...) | ...さらに多く |
Kutools for ExcelでExcelスキルを強化し、これまでにない効率を体験してください。 Kutools for Excelは、300以上の高度な機能を提供し、生産性を向上させ、保存時間を節約します。 最も必要な機能を入手するにはここをクリック...
Office TabはOfficeにタブインターフェイスをもたらし、作業を非常に簡単にします
- Word、Excel、PowerPoint、Publisher、Access、Visio、Projectでタブ付きの編集と読み取りを有効にします。
- 新しいウィンドウではなく、同じウィンドウの新しいタブで複数のドキュメントを開いて作成します。
- 生産性を50%向上させ、毎日数百回のマウスクリックを減らします!