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

VB.NET csvファイルの読み込みを行う方法

VB.NETcsvファイルの読み込みを行う方法を紹介します。

カンマ区切りだけでなく、任意の区切り文字を指定したり、ダブルクォーテーションの囲いなどにも対応します。

Using parser As New FileIO.TextFieldParser(FilePath, Encoding.GetEncoding("shift_jis"))
    'カンマ区切り
    parser.TextFieldType = FileIO.FieldType.Delimited
    parser.SetDelimiters(",")

    'ダブルクォーテーション囲い
    parser.HasFieldsEnclosedInQuotes = True

    'フィールドの空白を削除(トリム)
    parser.TrimWhiteSpace = True

    '1行ずつレコードを読込
    While Not parser.EndOfData
        Dim record As String()
        Try
            record = parser.ReadFields()
        Catch ex As Exception
            '不正レコードの場合は次のレコード
            Continue While
        End Try

        'csvの内容がString配列にセットされる
    End While
End Using

解説

ダブルクォーテーション囲いなどを考えると自力で文字列を解析するのは大変なので、FileIO.TextFieldParserを使用します。

第1引数に読み込むcsvファイルのパスを指定し、第2引数にはファイルの文字コードを指定します。

Using parser As New FileIO.TextFieldParser(ファイルパス, 文字コード)

parserのプロパティで区切り文字やダブルクォーテーション囲いなど、読み込むcsvファイルのフォーマットを指定します。

parser.ReadFields()csvの内容がString配列にセットされます。

形式が不正の場合はエラーが発生するのでTry Catchで不正レコードかどうかを判定しています。


関連記事

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

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


  • VB.NET YYYYMMDD書式の文字列が日付かどうか判定する

    VB.NETで、YYYYMMDD書式の文字列が日付として妥当かどうかを判定します。以下のように、Date.TryParseExactを使用して、日付型の文字列に変換可能かどうかで判定しています。Dat...


  • 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でString型の文字列を数値に変換する方法を紹介します。以下の例では、Integer型の数値に変換しています。文字列型の変数を数値型に変換する場合には以下に注意する必要があります。例えば...


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

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


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

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