C#

【C#】CsvHelper の使い方

利用準備

パッケージのインストール

PM> Install-Package CsvHelper

https://joshclose.github.io/CsvHelper/getting-started/

CSVファイルの作成

下記のような中身のCSVファイルを例にします

Id,Name,Age
1,永野芽衣,21
2,本田翼,28
3,戸田恵梨香,32

データ格納用クラスの作成

Index 属性を定義することで、CSVファイルの何列目かを指定できます。
また、Name 属性にCSVヘッダ名を定義することで、CSVのヘッダ名とプロパティ名を一致させる必要が無くなります。

今回はIndex 属性を使用します。

public class Person
{
    [Index(0)]
    public int Id { get; set; }
    [Index(1)]
    public string Name { get; set; }
    [Index(2)]
    public int Age { get; set; }
}

使い方

https://joshclose.github.io/CsvHelper/

CSVを読み取る

var filePath = @"C:\test\person_read.csv";
using (var reader = new StreamReader(filePath, Encoding.GetEncoding("Shift_JIS"))) //Shift-JISの文字化け対策にエンコード
{
    using (var csv = new CsvReader(reader, new CultureInfo("ja-JP", false))
    {
        //IEnumerable<Person>で返す
        var records = csv.GetRecords<Person>();
    }
}

CSVにヘッダがない場合は下記のようにコードで明示する必要があります。

var filePath = @"C:\test\person_read.csv";
using (var reader = new StreamReader(filePath, Encoding.GetEncoding("Shift_JIS"))) //Shift-JISの文字化け対策にエンコード
{
    var config = new CsvHelper.Configuration.CsvConfiguration(new CultureInfo("ja-JP", false))
    {
        //ヘッダ無(デフォルトtrue)
        HasHeaderRecord = false,
    };
    using (var csv = new CsvReader(reader, config))
    {
        var records = csv.GetRecords<Person>();
    }
}

CSVに書き出す

パスが存在しなくてもCSVファイルは生成されます。
逆にファイルが存在する場合は、上書きされます。

var filePath = @"C:\test\person_write.csv";
using (var writer = new StreamWriter(filePath, false, Encoding.GetEncoding("Shift_JIS"))) //Shift-JISの文字化け対策にエンコード
{
    using (var csv = new CsvWriter(writer, new CultureInfo("ja-JP", false))
    {
        var people = new List<Person>()
        {
            new Person(){Id=4,Name="川口春奈",Age=26 },
            new Person(){Id=5,Name="新垣結衣",Age=33 },
            new Person(){Id=6,Name="吉岡里帆",Age=28 },
        };
        csv.WriteRecords(people);
    }
}
var filePath = @"C:\test\person_write.csv";
using (var writer = new StreamWriter(filePath, false, Encoding.GetEncoding("Shift_JIS"))) //Shift-JISの文字化け対策にエンコード
{
  var config = new CsvHelper.Configuration.CsvConfiguration(new CultureInfo("ja-JP", false))
   {
        //ヘッダ無(デフォルトtrue)
        HasHeaderRecord = false,
    };
    using (var csv = new CsvWriter(writer, config)
    {
        var people = new List<Person>()
        {
            new Person(){Id=4,Name="川口春奈",Age=26 },
            new Person(){Id=5,Name="新垣結衣",Age=33 },
            new Person(){Id=6,Name="吉岡里帆",Age=28 },
        };
        csv.WriteRecords(people);
    }
}
エンジニアの転職ならこれ!

【第二新卒向け】マイナビジョブ20's

マイナビジョブ20'sは、20代・第二新卒・既卒向けの転職エージェントです。

▼こんな方におすすめ
・はじめて転職しようと思っている
・転職できるだけのスキルが自分にあるか不安
・手厚いサポートを受けたい

【フリーランス向け】安心保障と豊富な案件紹介 Midworks

Midworksは豊富な案件と「フリーランス」と「正社員」の良いとこ取りをした働き方を実現する手厚い保障が特徴です。

▼こんな方におすすめ
・現在正社員でフリーランスになろうか悩んでいる
・フリーランスとして働いているが、先行きが不安がある  (安定的な案件確保や保障など)
・自分の市場価値を知りたい、見合った案件で参画したい
・今後のキャリアビジョンを踏まえて案件を選びたい

【未経験向け】自宅で現役エンジニアから学べる TechAcademy

テックアカデミーは、現役エンジニアから学べるオンラインに特化したプログラミングスクールです。
講師は全員、通過率10%の選考に合格した現役エンジニア。
確かなスキルをもとに受講生をマンツーマンサポートします。


▼こんな方におすすめ
・自宅にいながらオンライン完結で勉強できる
・受講生に1人ずつ現役エンジニアのパーソナルメンターが専属でつく
・チャットで質問すればすぐに回答が返ってくる
・オリジナルサービスやオリジナルアプリなどの開発までサポート