C# と VB.NET の質問掲示板

ASP.NET、C++/CLI、Java 何でもどうぞ

ログ内検索
  • キーワードを複数指定する場合は 半角スペース で区切ってください。
  • 検索条件は、(AND)=[A かつ B] (OR)=[A または B] となっています。
  • [返信]をクリックすると返信ページへ移動します。
キーワード/ 検索条件 /
検索範囲/ 強調表示/ ON (自動リンクOFF)
結果表示件数/ 記事No検索/ ON
大文字と小文字を区別する

No.86697 の関連記事表示

<< 0 >>
■86697  Re[3]: DataGridView内のデータのキャストについて
□投稿者/ WebSurfer -(2018/02/28(Wed) 11:14:51)
    No86696 (MTK さん) に返信

    > ウォッチで this.DataGridView1[ i, s ].Value の型を見てみると object{string} となっています。

    であれば、質問者さんのコード、

    > if ( this.DataGridView1[ i, s ].Value is long )

    の if 文の条件が false になって合計は得られないのは当然の結果なのですが。

    ちなみに、is 演算子というのは MSDN ライブラリによると "is 式は、指定した式が null 以外であり、
    指定したオブジェクトを指定した型に例外がスローされることなくキャストできる場合に、true と評価
    されます。" ということだそうです。

    なので、上記のコードの例では ture にならない(false になる)ということです。

    何かしたいのかよく分かりませんが、想像をふくらませると、"ABC", "あいう", "123" という文字列が
    格納されていて、"123" だけ取り出して合計したいということではないかと思うんですが、どうでしょう?

    であれば、文字列を希望の数値型(long 型?)パースできるかどうかを調べて、パース可能ならばパース
    して合計するということになるはずです。
記事No.86693 のレス /過去ログ148より / 関連記事表示
削除チェック/



<< 0 >>

パスワード/

- Child Tree -