Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/csharp/332.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# CsvReader忽略空白列_C#_Winforms_Csv_Csvhelper - Fatal编程技术网

C# CsvReader忽略空白列

C# CsvReader忽略空白列,c#,winforms,csv,csvhelper,C#,Winforms,Csv,Csvhelper,我第一次使用CSVhelper。另一个程序正在导出csv文件该文件如下所示 ,"Employee","Earnings 1/Rate","Note" ,"John Doe","Regular 10.50", "Started Sep 1" 问题是我一开始就有一个空白栏要处理。我不希望用户必须使用excel删除列才能使用该文件。因此,我如何可以忽略第一列或获取要添加到数据表中的列 错误(请参阅程序底部附近的注释行)为空白字段,csv文件中不存在该字段 我的班级在阅读资料 namespace Pa

我第一次使用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);
        }
    }
}
命名空间PayRateTracker
{
公共类测试记录
{
公共字符串空白{get;set;}
公共字符串Employee{get;set;}
公共字符串{get;set;}
公共字符串注释{get;set;}
}
公共类MyClassMap:CsvClassMap
{
public override void CreateMap()
{
Map(m=>m.Blank)指数(0);
Map(m=>m.Employee)指数(1);
Map(m=>m.Learning)。指数(2);
Map(m=>m.Note)。索引(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;
        }
    }
}
命名空间PayRateTracker
{
公共部分类Form1:Form
{
公共表格1()
{
初始化组件();
//流读取器将读取当前文件夹中的test.csv文件
StreamReader sr=新的StreamReader(@“G:\2013-09-20.csv”);
//Csv阅读器读取流
CsvReader csvread=新CsvReader(sr);
//csvread将一次性获取IEnumerable对象记录的所有记录
IEnumerable记录=csvread.GetRecords();
//foreach(记录中的var rec)//每个记录都将被提取并打印在屏幕上
//{
//lblDisplay.Text=(string.Format(“名称:{0},金额:{1},注释:{2}
”,记录员工,记录收入,记录注释)); //} 高级关闭(); } 私有无效按钮1\u单击(对象发送者,事件参数e) { DataTable dt=新的DataTable(); 使用(var stream=File.OpenRead(@“G:\Test.csv”)) { 使用(变量读取器=新的流读取器(流)) { 使用(var csvReader=新csvReader(读卡器)) { csvReader.Configuration.RegisterClassMap(); int i=0; while(csvReader.Read()) { if(csvReader.FieldHeaders[0]==“”) { csvReader.FieldHeaders[0]=“空白”; } 如果(i==0) { foreach(csvReader.FieldHeaders中的变量字段) { dt.Columns.Add(字段); } } DataRow row=dt.NewRow(); foreach(csvReader.FieldHeaders中的变量字段) {
row[field]=csvReader.GetField(field);//这里的问题是,您正在查看标题,如果您看到一个空白标题,您将其改为
“blank”
。现在,当您循环字段标题时,您正试图通过
“blank”
获取该字段,而这是不存在的

是否需要空白列作为数据表的一部分?

您可以在这里进行一些更改

您已经创建了一个类和一个映射,但没有使用它们中的任何一个。您可以这样做:

var records = csvReader.GetRecords<TestRecord>();
看起来您可能只想使用相同的标题将CSV文件中的内容放入数据表中,如果是空的,则改为“空白”。您可以稍微修改当前代码

row[0] = csvReader[0];
// Skip the first column.
for( var j = 1; j < csvReader.FieldHeaders.Length; j++ )
{
    row[j] = csvReader[j];
}
行[0]=csvReader[0];
//跳过第一列。
对于(var j=1;j
这里的问题是,您正在查看标题,如果您看到一个空白标题,您将其改为
“blank”
。现在,当您循环字段标题时,您正试图通过
“blank”
获取字段,而该字段不存在

是否需要空白列作为数据表的一部分?

您可以在这里进行一些更改

您已经创建了一个类和一个映射,但没有使用它们中的任何一个。您可以这样做:

var records = csvReader.GetRecords<TestRecord>();
看起来您可能只想使用相同的标题将CSV文件中的内容放入数据表中,如果是空的,则改为“空白”。您可以稍微修改当前代码

row[0] = csvReader[0];
// Skip the first column.
for( var j = 1; j < csvReader.FieldHeaders.Length; j++ )
{
    row[j] = csvReader[j];
}
行[0]=csvReader[0];
//跳过第一列。
对于(var j=1;j
没有“神奇”的方法来实现它-您需要为它编写代码。检测列是否为空,并在将数据添加到数据库时跳过空格。现在会发生什么,您是否会遇到异常?为什么不简单地
foreach(csvReader.FieldHeaders.Where(h=>string.IsNullOrWhiteSpace(h))呢…
?我尝试了上述解决方案。我用if语句注释掉了创建标题“Blank”的内容。我更改了在csvReader中循环的两行内容。但是,我在同一行中得到了相同的错误。除了这次它说“列”不属于表之外,没有“魔力”实现方法-您需要为其编写代码。检测列是否为空,并在将数据添加到数据库时跳过空格。现在会发生什么,您是否会遇到异常?为什么不简单地
foreach(csvReader.FieldHeaders.Where中的var字段(h=>string.IsNullOrWhiteSpace(h)))…
?我尝试了上面的解决方案。我用if语句注释掉了创建标题“Blank”的内容。我更改了循环通过