C#で正規表現が使えたらな〜って時は以外と多いので、ちょっと正規表現を頑張って使ってみた。

投稿日:2017-02-03

あー、正規表現が使えたらな〜って時は以外と多いので、ちょっと正規表現を頑張って使ってみた。

別にC#に限らないんだけど、ソースの中に正規表現を書く時の書き方?っていうのかな。が分からなかったので、調べてみた。

[C#] 正規表現で半角英数以外を弾く
http://www.remember-the-time.xyz/2012/04/c_20.html

参考にしたのは上記サイト。

っていうか、ちょうど、自分がやりたかった事だったので、ビンゴだった。


using System.Text.RegularExpressions;
flg = 1; //1:半角英数 2:電話番号 3:郵便番号...
strCheckText = "あいうえおabcde";
if (flg == 1 && !(Regex.Match(strCheckText, "^[a-zA-Z0-9]+$")).Success)
{
// 半角英数以外の文字が含まれています。
}else if (flg == 2 && !(Regex.Match(strCheckText, "^[0-9]{2,5}-[0-9]{1,4}-[0-9]{4}$")).Success)
{
// 0-9以外が入力されています。
}

数値 : ^[0-9]+$
郵便番号 : ^[0-9]{3}[-][0-9]{4}$
電話番号 : ^[0-9]{2,5}-[0-9]{1,4}-[0-9]{4}$
全角かな : ^[ぁ-ん!ー]+$
全角カナ : ^[ァ-ヴ!ー]+$
半角カナ : ^[ア-゙]+$

ほぼ、引用になるけど、こんな感じで分ける事が出来て非常に助かった。

ちょうど同じようなシチュエーションで入力値のチェックをしなきゃって状態で、電話番号だったり、物理名(アルファベット・数字)だったり、論理名(日本語含む)だったりがコンボボックスで変化するっていう画面での入力値チェックっていう。

なので、仮に


if(textbox.text == 0 || textbox.text == 1 ..... || textbox.text == 9)
{

}

こんな感じで、0〜9までの入力チェックとか、加えて電話番号みたいに「+」「-」だけは入力可にするとか使い道は色々あると思う。

ただ、今の会社での開発状況的に、そういったチェック関数的なものは用意されておらず、各フォーム単位でやらざるを得ないので、結局、テキストボックス単位でのバリデーションになるし、画面担当者毎に開発流儀が違って、上みたいにゴリゴリ書く(自分も割とそのタイプ)人だったり、フォーム内で使えるようにクラスを作る人もいるし、でバラバラな状況w

で、結局、フォームの修正として自分に割り当てられてから、ソースを確認して、どっちなのかが分かるっていうw

その時に、どの入力されるテキストボックス毎に、電話番号だったり名称だったり、物理名(アルファベット・数字)だったりで、チェック条件が一致せず、分けざるを得ないこともしばしばあって、そういう時に正規表現だと、バカみたいにソースを追加しなくていいだろうなって、ずっと考えていたので、今後は正規表現を使ってコード量を減らしていきたい。

っていうか、外注した画面のソースを見て見ると、


if(textbox.text == 0 || textbox.text == 1 ..... || textbox.text == 9)
{

}

マジで、こんな感じで条件を追加していって、アルファベットも対応してたりする。

余計な書き方を追加してエラーを増やさない為といえば聞こえはいいけど、条件の追加漏れが発生したり、簡易な変更であっちもこっちも修正しなきゃいけなくなって、非常に効率が悪いって思ったのがきっかけで正規表現を使えたら、コード量減るし、条件の追加・修正漏れが発生しないのになって思ったのがきっかけで正規表現を使ってみようと考えて満足いく結果になったので、良しとする。

ただ、今所属してるプロジェクト的に、同様の修正が発生する画面はたくさんあるので、今後そういう画面に当たらないとも限らないっていう話。







-C#, PC, 開発メモ
-, ,


comment

メールアドレスが公開されることはありません。 が付いている欄は必須項目です

関連記事

VisualStudioでデータテーブルの中身確認できるの便利すぎワロタw

DataSetビジュアライザーで、DataTableの中身が確認できるのが便利すぎたのでメモ。 データテーブルって気軽に使えるけど、中身の確認がしち面倒くさい件 本当のところはどうなのか?ってのは知ら …

Excelで任意の位置に画像を貼り付ける方法

Excelで資料を作る際、ほぼ必須だと思う作業の1つが、画像の貼付。 基本的には、Excelのセルを選んだところに画像は貼り付く・・・はずなんです。 が、場合によっては、セルの位置に張り付かず、A1セ …

[Windows]タスクバーに表示される「最近使ったもの」が多すぎて消せないので、一括削除する方法

さて、Windows使いの人なら、地味に便利に使っている・・・かもしれない「最近使ったもの」という一覧。 確かに、同じフォルダを開きたい時とかは重宝します。 が、たまにウザいw 場合によっては消さなき …

先日のデグレに引き続き、作業を一個抜かしたら、超絶怒られて始末書書かされた件

タイトルの通りで、始末書書かされました。 社内での信用0です。 先日のデグレの時もでしたが、今日も思いっきり怒られましたよ。 電話越しの無言は怖い。 日本の中心付近で仕様変更と闘うSE日記 1 Use …

ADO.NET Entity Data Model をOracleで使う

かれこれ数ヶ月のエラー 以前、会社のノートPCのHDDをSSDに変えたわけですが、それからずっと、あるエラーに悩まされておりまして・・・ その内容は、 エラー 175: 不変名が ‘Ora …


カテゴリー