zukucode
主にWEB関連の情報を技術メモとして発信しています。

VB.NET DataTableの列の値を配列に変換する

VB.NETDataTableの指定した列の値を配列に変換して取得したい場合があります。

IDNAME
1りんご
2ばなな
3みかん
4いちご
指定した列を配列にしたい
{"りんご", "ばなな", "みかん", "いちご"}

For Eachなどで1行づつループで配列に追加していく方法もありますが、匿名関数(無名関数/ラムダ式)を使用すれば簡単に取得できます。

Dim dt As DataTable '例のテーブル

'配列で取得
Dim arr As String() = dt.AsEnumerable().Select(Function(row) row("NAME")).ToArray()

'{"りんご", "ばなな", "みかん", "いちご"}

Select()の中に記載した匿名関数の処理がDataTableの1行ごとに行われます。

匿名関数の処理は複数行で記載できるため、自由にデータを加工できます。

Dim dt As DataTable '例のテーブル

'配列で取得
Dim arr As String() = dt.AsEnumerable().Select(Function(row)
                                                  If row("ID").ToString = "2" Then
                                                      'ばななの場合は空文字にする
                                                      Return ""
                                                  End If
                                                  Return row("NAME").ToString
                                              End Function).ToArray()

'{"りんご", "", "みかん", "いちご"}

DataTableに対してAsEnumerableを使用するにはSystem.Data.DataSetExtensionsをプロジェクトの参照に追加する必要があります。

System.Data.DataSetExtensionsは.NET framework 3.5以上で使用できます。

VB.NET 配列をカンマ区切りの文字列に変換するで紹介した方法と組み合わせれば、SQLなどで取得したデータをカンマ区切りやスラッシュ区切りの文字列に簡単に変換することができます。

カンマ区切りの文字列に変換
Dim dt As DataTable '例のテーブル

'配列で取得
Dim str As String = String.Join(",", dt.AsEnumerable().Select(Function(row) row("NAME")).ToArray())
Console.WriteLine(str)

'出力結果
'りんご,ばなな,みかん,いちご

関連記事

  • VB.NET YYYYMMDD形式の文字列を日付型に型変換する

    VB.NETでYYYYMMDD形式の文字列を日付型に型変換する方法を紹介します。最初にYYYY/MM/DDのように、年月日の区切りに/を追加します。/区切りの文字列にするとCDateで日付型に型変換で...


  • VB.NET 文字列の全角と半角の変換を行う

    VB.NETで文字列を全角→半角や半角→全角に変換するにはStrConv関数を使用します。StrConvの第1引数に対象文字列を指定し、第2引数に変換方法を指定します。


  • VB.NET TypeOfで変数の型判定・比較を行う

    VB.NETで変数の型をチェックするにはTypeOfを使用します。TypeOf チェックしたい変数名 Is 判定したい型の形式で指定します。


  • VB.NET StringBuilderの末尾の1文字を削除する

    StringBuilderで末尾の1文字だけ削除したいときは以下のようにします。位置の指定について、1文字目は0から始まるため、文字列の長さ(Length)-1の位置が末尾の位置となります。末尾の位置...


  • VB.NET 指定した文字列を削除する

    VB.NETで指定した文字列を削除する方法を紹介します。Replace関数は指定した文字列を別の文字列に置換する関数です。置換する文字列に空文字を指定すれば、指定した文字列が削除される形になります。J...


  • VB.NET ダブルクォーテーションを文字列として扱う方法

    VB.NETで文字列を扱うときは以下のようにダブルクォーテーションで囲います。文字列の中にダブルクォーテーションを含めたい場合は少し工夫が必要です。以下のようにダブルクォーテーションを2つにすれば1つ...


  • VB.NET 文字列を連結する便利な方法まとめ

    VB.NETでは文字列の連結は文字列同士を&で結合できます。Visual Studio 2015からの新機能として文字列補間が可能になりました。以下のように、文字列の前に$をつけることにより、文字列の...


  • VB.NET 文字列をカナ、全角半角、大文字小文字などを区別せずに比較する方法

    VB.NETで文字列をひらがなカタカナ、全角半角、大文字小文字を区別せずに、前方一致や部分一致で検索する方法をまとめて紹介します。例えばあいうえおという文字列にうえという文字列が含まれているかどうか判...


  • VB.NET バイト配列と文字列を相互変換する

    バイト配列を文字列を相互変換する方法を紹介します。データベースからblob型の値を取得した時や、アップロードされたファイルの中身を取得した時などはバイト配列で取得することが多いです。エンコード形式を指...


  • VB.NET 任意の区切り文字のある文字列を配列に変換する

    VB.NETで任意の区切り文字のある文字列を配列に変換する方法を紹介します。文字列を配列に変換するにはSplitを使います。文字列.Split(区切り文字)で配列に変換できます。