0

所以这是我的问题。

我正在将 CSV 读入 datagridview。csv 的第一行是列标题,文件的成为行。我正在读取文件并用作 datagridview 的数据源。但是 CSV 中的某些行具有类似于

名称,测试,1,2,3,测试,2 ,3,2,1,测试,名称

当我使用.Split()它时,它在上面加粗的地方认为它是行中的一个新单元格,但是列数是 10 而不是 11,我收到以下错误:

输入数组长于此表中的列数

我该如何解决这个问题。

下面是我的 C# 代码。

OpenFileDialog openFile = new OpenFileDialog();
        openFile.InitialDirectory = "c:\\";
        openFile.Filter = "txt files (*.txt)|*.txt| CSV Files (*.csv) | *.csv| All Files (*.*) | *.*";
        openFile.FilterIndex = 2;
        openFile.RestoreDirectory = true;
        try {
            if (openFile.ShowDialog() == DialogResult.OK)
            {
                string file = openFile.FileName;
                StreamReader sr = new StreamReader(file);

                /* gets all the lines of the csv */
                string[] str = File.ReadAllLines(file);

                /* creates a data table*/
                DataTable dt = new DataTable();

                /* gets the column headers from the first line*/
                string[] temp = str[0].Split(',');

                /* creates columns of the gridview base on what is stored in the temp array */
                foreach (string t in temp)
                {
                    dt.Columns.Add(t, typeof(string));
                }

                /* retrieves the rows after the first row and adds it to the datatable */
                for (int i = 1; i < str.Length; i++)
                {
                    string[] t = str[i].Split(',');
                    dt.Rows.Add(t);
                }

                /* assigns the data grid view a data source based on what is stored in dt  */
                dataGridView1.DataSource = dt;
            }
        }
        catch (Exception ex) 
        {
                MessageBox.Show("Error: The CSV you selected could not be loaded" + ex.Message);
        }
4

1 回答 1

1

这听起来更像是数据问题而不是编程问题。如果您的 CSV 文件应该有 10 列但有些有 11 列,那么您如何知道哪一列是多余的列?

您可以做的一件事是在添加行之前检查列数。

for (int i = 1; i < str.Length; i++)
{
    string[] t = str[i].Split(',');
    if(t.Length == temp.Length)
        dt.Rows.Add(t);
}
于 2013-04-06T01:01:47.413 回答