1

我有一个这样的字符串:

"X","Y","Z"
"X2","Y2","Z2"

即,由包含多个不同字符串值的新行分隔的多行,这些字符串由逗号分隔。

我如何创建一个函数来将这些值输入到这样的数据表中:

"X" "Y" "Z"
"X2" "Y2" "Z2"

对于我的字符串中的任意数量的行和列?

这是我到目前为止所拥有的:

public static DataTable writeToDT(string data) //Write to datatable from string
    {
        DataTable dataTable = new DataTable();
        foreach (string header in csvHeader)
        {
            dataTable.Columns.Add(header);
        }
        using (StringReader reader = new StringReader(data))
        {
            string line;
            while ((line = reader.ReadLine()) != null)
            {
                DataRow dataRow = dataTable.NewRow();
            }
        }
        return dataTable;
    }

我的数据中的标题在哪里csvheader填充了一个数组。
我相信这会创建一个包含适量行和列的空数据表,但我不确定如何用我拥有的字符串数据填充它。

提前致谢。

4

1 回答 1

1

像这样的东西应该工作。解析 CSV 是一个已解决的问题,命名空间TextFieldParser中的类using Microsoft.VisualBasic.FileIO;(添加对 的引用Microsoft.VisualBasic)可以为您做到这一点。

public static DataTable WriteToDataTable(string data)
{
    DataTable dataTable = new DataTable();
    foreach (var header in csvHeader)
        dataTable.Columns.Add(header);

    using (var reader = new StringReader(data))
    {
        TextFieldParser csvParser = new TextFieldParser(reader) { HasFieldsEnclosedInQuotes = true, Delimiters = new string[] { "," } };

        while (!csvParser.EndOfData)
        {
            var dataTableRow = dataTable.NewRow();
            dataTableRow.ItemArray = csvParser.ReadFields();
            dataTable.Rows.Add(dataTableRow);
        }
    }
    return dataTable;
}
于 2015-01-31T16:53:55.343 回答