0

我想用 CSV 文件中的数据填充前几列

我正在使用的代码:

...
   DataTable dataTable = (DataTable)readCsvTable(openFileDialog1.FileName);
   if (dataTable != null) dataGridViewQuestions.DataSource = dataTable; 
...


 private DataTable readCsvTable(string filename) 
    {
        DataTable dtDataSource = new DataTable();

        try
        {
            string[] fileContent = File.ReadAllLines(filename);

            if (fileContent.Count() > 0)
            {
                //Create data table columns
                string[] columns = fileContent[0].Split(',');
                for (int i = 0; i < columns.Count(); i++)
                {
                    dtDataSource.Columns.Add(columns[i]);
                }

                //Add row data
                for (int i = 1; i < fileContent.Count(); i++)
                {
                    string[] rowData = fileContent[i].Split(',');
                    dtDataSource.Rows.Add(rowData);
                }
            }
        }
        catch (Exception ex) {
            ...
            //error msgbox
            ...
            return null;
        }
        return dtDataSource;
    }

问题:

当 AutoGenerateColumns = true - 代码导致附加列(如果文件由同一应用程序导出,则与 DataGridView 中的前几列名称相同)被添加到 gridView 并填充适当的数据。

当 AutoGenerateColumns = false - 上面的代码将正确的行数添加到表中,并且没有添加新列但行是空的。

已经尝试过:

通过列的 HeaderText 和列的控件名称调用 CSV 文件中的列,制作与 DataGridView 列数相同的 CSV 文件和制作列数较少的文件,没有区别。

4

2 回答 2

1

我刚刚尝试过模拟它,它按预期工作。切换文件时是否抛出异常?

在尝试解析文件之前,您可以尝试将数据源设置为 null,以便查看它是否达到那么远?

dataGridViewQuestions.DataSource = null;
DataTable dataTable = readCsvTable(openFileDialog1.FileName);
if (dataTable != null) 
     dataGridViewQuestions.DataSource = dataTable; 
于 2013-03-05T08:12:50.200 回答
1

如果从“AutoGenerateColumns = true”填充的数据使用它。如果前面的列是您的问题,那么您可以为该 datagridview 创建新实例;

...
if (dataTable != null)
{
    dataGridViewQuestions = new DataGridView();
    dataGridViewQuestions.DataSource = dataTable;
}
...
于 2013-03-05T08:22:57.613 回答