C#でTryParseメソッドを使って文字列が数値かどうかを確認する

投稿日:

C#に限らず、コーディングしていると数値が欲しいのに、引数がstring型とかいう状況がよくあるわけで。

判定方法はいろいろあるけど、TryParseを使うと簡単だった。

TryParseって何するの?

方法: 文字列が数値を表しているかどうかを確認する (C# プログラミング ガイド)

MicrosoftのC#プログラミングガイドによると、

文字列が数値以外の文字、または指定した型で表すには大きすぎる (または小さすぎる) 数値の場合、TryParse は false を返し、out パラメーターを 0 に設定します。 それ以外の場合は true を返し、out パラメーターを文字列の数値に設定します。

例えば、「100」という文字列がint型なのかを判定し、int型であればパラメータに「100」をint型として返します。
int型でなければ、パラメータには「0」が設定される。

紹介されている例だと、

  • result = true
  • i = 108

となります。


int i = 0;

string s = "108";

bool result = int.TryParse(s, out i); //i now = 108

力技で判定すると

int i = 0;

string s = "108";

for(int keta = 1; keta < 4; keta++)
{
    for(int moji = 0; moji < 10; moji++)
    {
        if(s.Substring(keta,1).ToString() == moji.ToString())
        {
            Console.WriteLine("文字");
        }
    }
}

Console.WriteLine("数値");

多分、こんな感じで1桁ずつ0~9のどれかに当てはまるかを判定するとか。

コレに比べたら、1行で判定と数値に変換した値を返してくれるTryParseはいい。

他の方法

「(int)」を先頭につけてキャストしてしまう方法もあるけど、数値以外が入った瞬間に破綻するコードになるので、絶対に数値しか入力されないっていう縛りがなければ使えない。

 

 

 







-C#
-

関連記事

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

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

C# OracleDbAccessを使用して、SQL実行時にORA-00911 文字が無効です のエラー

表題のとおり、C#でOracleDbAccessを使用して、SQLを実行させる時に発生しました。 ネットで探すと、 全角スペースが原因 とか出てきたので、SQL内のスペースを全て半角スペースに置き換え …

SyntaxHighlighter EvolvedっていうWordPressのプラグインを使ったら、楽にソースコードを表示できた。

SyntaxHighlighter Evolvedっていうプラグインを使って、コードの表示を楽にしてみた。 C#で正規表現が使えたらな〜って時は以外と多いので、ちょっと正規表現を頑張って使ってみた。 …

Excelでシートをコピーする時に、「名前が既に存在します。」と言われるのを回避して、Excel出力を早くしたい。

結論から書いてしまうと、名前の重複を削除しても、Excelの出力は別に早くならなかった。 早くなるという意味だと、手動でシートをコピーした時に、いちいちダイアログの対応をしなくて済むので、自分で作業し …

[C#]文字を繰り返したものを取得したい。

いちいちfor文とかで繰り返すのも効率が悪いなと思ってたので、処理を関数化・・・ ただ、共通関数として登録しないので、別のところで使いたい場合は、同じ関数が複数登録されちゃうことに・・・ 更には、思い …


カテゴリー