1

初めてCSVhelperを使用しています。別のプログラムがcsvファイルをエクスポートしています。ファイルは次のようになります

,"Employee","Earnings 1/Rate","Note"
,"John Doe","Regular 10.50", "Started Sep 1"

問題は、最初に対処する空白の列があることです。ファイルを使用するために、ユーザーが Excel を使用して列を削除する必要はありません。では、最初の列を無視するか、データテーブルに追加する列を取得するにはどうすればよいですか。

エラー (プログラムの下部にあるコメント行を参照) は、フィールド ブランクが csv ファイルに存在しません

データを読み込むための私のクラス

namespace PayRateTracker
{
    public class TestRecord
    {
        public string Blank { get; set; }
        public string Employee {get; set;}
        public string Earning { get; set; }
        public string Note { get; set; }
    }

    public class MyClassMap : CsvClassMap<TestRecord>
    {
        public override void CreateMap()
        {
            Map(m => m.Blank).Index(0);
            Map(m => m.Employee).Index(1);
            Map(m => m.Earning).Index(2);
            Map(m => m.Note).Index(3);
        }
    }
}

エラーが下部近くで発生しているというコメントがあります

namespace PayRateTracker
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();

             //Stream reader will read test.csv file in current folder
             StreamReader sr = new StreamReader(@"G:\2013-09-20.csv");

             //Csv reader reads the stream
             CsvReader csvread = new CsvReader(sr);

            //csvread will fetch all record in one go to the IEnumerable object record
             IEnumerable<TestRecord> record = csvread.GetRecords<TestRecord>();

             //foreach (var rec in record) // Each record will be fetched and printed on the screen
             //{
             //    lblDisplay.Text = (string.Format("Name : {0}, Amount : {1}, Notes : {2} <br/>", rec.Employee, rec.Earning, rec.Note));
             //}
             sr.Close();
        }

        private void button1_Click(object sender, EventArgs e)
        {
            DataTable dt = new DataTable();
            using (var stream = File.OpenRead(@"G:\Test.csv"))
            {
                using (var reader = new StreamReader(stream))
                {
                    using (var csvReader = new CsvReader(reader))
                    {
                        csvReader.Configuration.RegisterClassMap<MyClassMap>();
                        int i = 0;
                        while (csvReader.Read())
                        {
                            if (csvReader.FieldHeaders[0] == "")
                            {
                                csvReader.FieldHeaders[0] = "Blank";
                            }
                            if (i == 0)
                            {
                                foreach (var field in csvReader.FieldHeaders)
                                {
                                    dt.Columns.Add(field);
                                }
                            }

                            DataRow row = dt.NewRow();
                            foreach (var field in csvReader.FieldHeaders)
                            {
                                row[field] = csvReader.GetField(field);  // <-- Error here
                            }
                            dt.Rows.Add(row);

                            i += 1;
                        }
                    }
                }
            }
            //return dt;
            dataGridView1.DataSource = dt;
        }
    }
}
4

1 に答える 1

1

ここでの問題は、ヘッダーを見ていて、空のヘッダーが表示されている場合は、"Blank"代わりに変更していることです。フィールドヘッダーをループしているときに、フィールドを取得しようとしていますが"Blank"、これは存在しません。

データ テーブルの一部として空白の列が必要ですか?

ここで行うことができるいくつかの変更があります...

クラスとマッピングを作成しましたが、どちらも使用していません。あなたはこれを行うことができます:

var records = csvReader.GetRecords<TestRecord>();

recordsになりますIEnumerable<TestRecord>

空白の列はどこにも使用されていないように思われるため、そのマッピングを削除できます。

public class MyClassMap : CsvClassMap<TestRecord>
{
    public override void CreateMap()
    {
        Map(m => m.Employee).Index(1);
        Map(m => m.Earning).Index(2);
        Map(m => m.Note).Index(3);
    }
}

また、同じヘッダーを使用してCSVファイルにあるものをデータテーブルに入れたいだけのように見えますが、空の場合は代わりに「空白」にします。現在のコードを少し変更するだけです。

row[0] = csvReader[0];
// Skip the first column.
for( var j = 1; j < csvReader.FieldHeaders.Length; j++ )
{
    row[j] = csvReader[j];
}
于 2013-10-11T19:28:05.693 に答える