我需要帮助将两个不同的行(具有相同的列)添加到同一个数据表中

问题描述 投票:0回答:1

在Windows窗体应用程序上工作,从csv文件读取数据并将数据添加到Datagridview。我遇到了一个问题,所有行都被添加到datable并显示在datagridview上。 datagridview显示前两个数据行的条件,如果条件,则显示OneRow仅条件。如果条件行使用OneRow填充datable和datagridview行,则不会添加来自twoRow的行。但我希望OneRow和TwoRow的行都显示出来。当我评论(/ ** /)出OneRow if条件时,TwoRow中的行会填充数据表和数据视图。但我需要两者填充表格。提前致谢!

        Construct.MainDataTable.Columns.Add("Date", typeof(DateTime));
        Construct.MainDataTable.Columns.Add("Time");
        Construct.MainDataTable.Columns.Add("Serial");
        Construct.MainDataTable.Columns.Add("Type");
        Construct.MainDataTable.Columns.Add("level");
        Construct.MainDataTable.Columns.Add("price");
        Construct.MainDataTable.Columns.Add(" Limit");
        Construct.MainDataTable.Columns.Add("last Limit");
        Construct.MainDataTable.Columns.Add("Data");
        ..........................
    ...............................................
        DataRow oneRow = Construct.MainDataTable.NewRow();
        DataRow twoRow = Construct.MainDataTable.NewRow();
        dataGridView2.AllowUserToAddRows = false;

        if (line.Split(',')[2].Equals("Time"))
        {
         time = line.Split(',')[3];
         date = line.Split(',')[1];
         }
        if (line.Split(',')[2].Equals("Level"))
        {
         level = line.Split(',')[3];

         }
        //OneROw(IF condition)
        if ((Convert.ToDecimal(line.Split(',')[8])) < (Convert.ToDecimal     (line.Split(',')[12]))) 
        {

          type = line.Split(',')[1];
          serial = line.Split(',')[7];
          price = line.Split(',')[3];
          Limit = line.Split(',')[8];
          lastLimit = line.Split(',')[10];
          Data = line.Split(',')[12];

          oneRow["Date"] = date;
          oneRow["Time"] = time;
          oneRow["Serial"] = serial;
          oneRow["Type"] = type;
          oneRow["level"] = level;
          oneRow["price"] = price;
          oneRow[" Limit"] = Limit;
          oneRow["last Limit"] = lastlimit;
          oneRow["Data"] = Data;
          Construct.MainDataTable.Rows.Add(oneRow);
         }  
       //TwoROw(IF condition)                             
        if ((line.Contains('"')) && ((line.Contains("NG"))))
        {
          price = line.Split(',')[3];
          type = line.Split(',')[1];
          serial = line.Split(',')[7];
          Limit = line.Split('"')[7];
          var valLimit = Limit.Split(',').Select(a => Convert.ToInt32(a, 16));
          var limitJoin = String.Join(",", valLimit);
          lastlimit = line.Split('"')[1];
          var vallastLimit = lastlimit.Split(',').Select(d => Convert.ToInt32(d, 16));
          var lastJoin = String.Join(",", vallastLimit);
          Data = line.Split('"')[5];
          var valDatas = Data.Split(',').Select(s => Convert.ToInt32(s, 16));
          var dataJoin = String.Join(",", valDatas);
          twoRow["Date"] = date;
          twoRow["Time"] = time;
          twoRow["Serial"] = serial;
          twoRow["Type"] = type;
          twoRow["level"] = level;
          twoRow["price"] = price;
          twoRow["Limit"] = limitJoin;
          twoRow["last Limit"] = lastJoin;
          twoRow["Data"] = dataJoin;
          Construct.MainDataTable.Rows.Add(twoRow);
          }
         dataGridView2.DataSource = Construct.MainDataTable;
c# datagridview datatable row datagridviewcolumn
1个回答
0
投票

无法添加评论,因为我没有足够的业力,所以我在这里问我的问题:那么,如果我理解你的问题你不能从一个.csv文件中添加数据,如果它有多于一行?为什么在.csv文件中使用2个不同的if条件?

如果行中有空数据,请不要介意将它们放在DataTable列中,这样就可以使用循环将.csv中的数据添加到DataTable中。尝试这样的事情:

    public static DataTable CsvToDataTable(string csv)
    {
        DataTable dt = new DataTable();
        string[] lines = csv.Split(new[] { "\r\n", "\r", "\n" }, StringSplitOptions.RemoveEmptyEntries);
        Regex onlyDeimiterComma = new Regex(",(?=(?:[^\"]*\"[^\"]*\")*(?![^\"]*\"))");

        for (int i = 0; i < lines.Length; i++)
        {
            DataRow row = dt.NewRow();
            string[] cells = onlyDeimiterComma.Split(lines[i]);

            for (int j = 0; j < cells.Length; j++)
            {
                if (i == 0)
                { 
                    if (j == 0)
                    {
                        dt.Columns.Add(cells[j], typeof(DateTime));
                    }
                    else
                    {
                        dt.Columns.Add(cells[j]);
                    }                   
                }
                else
                {
                    row[j] = cells[j];
                }
            }

            dt.Rows.Add(row);
        }

        return dt;
    }

只需在代码中的任何位置调用此方法,并从.csv文件中读取字符串。您可以尝试编译此代码here并查看它如何在.csv数据上使用不同的数据(空列,引用文本,引用逗号)

UPD:如果您需要从两个不同的.csv文件中填充DataTable,您仍然可以使用上面的代码。只需为两个文件调用两次,然后合并两个DataTable,如下所示:

DataTable dt = CsvToDataTable(csvFileOne);
DataTable dtTwo = CsvToDataTable(csvFileTwo);
dt.Merge(dtTwo);
© www.soinside.com 2019 - 2024. All rights reserved.