1

我在我的 sql 数据库中导入 .csv 文件。我正在使用 TextFieldParser。

我的代码是

TextFieldParser parser = new TextFieldParser(file); 
//single file 
//TextFieldParser parser = new TextFieldParser(CSVFolderPath + "\\" + file); 
parser.TextFieldType = FieldType.Delimited; 
parser.SetDelimiters(","); 
int k = 0; 
while (!parser.EndOfData) 
{ 
    //Processing row 
    string[] fields = parser.ReadFields(); 
    if (k != 0) 
    { 
        for (int i = 0; i < fields.Length; i++) 
        { 
            stationcode = fields[0].ToString().Substring(4, 5); 
            //if (fields[1].ToString().Substring(14, 8) == date) 
            //{ 
            if (i == 0) 
            { 

                dr = workTable.NewRow(); 
                dr[i] = fields[i].Substring(0, fields[i].Length - 4);  

            } 
            else if (i == 3) 
            { 
                dr[i] = Convert.ToDateTime(fields[i].ToString()); 
            } 
            else if (i == 4) 
            { 
                dr[i] = Convert.ToDateTime(fields[i].ToString()); 
            } 
            else if (i == 5) 
            { 
                dr[i] = Convert.ToInt32(fields[i].ToString()); 
            } 
            else 
                dr[i] = fields[i].ToString(); 
            if (i == 5) 
            { 
                workTable.Rows.Add(dr); 
            } 
            //} 

        } 
    } 
    k = k + 1; 
} 
parser.Close();     

这里的工作表是DataTable。

代码解析文件很好。

但在我的 csv 文件中,最后一行用于摘要。一些字段的总和。

我不想包含该行以插入数据表。

我怎样才能做到这一点 ?

4

3 回答 3

0

如果您的最后一行以某个特定字符串(例如“Summary”)开头,则可以使用 TextFieldParser 类的 CommentTokens 属性。

请参阅:http: //msdn.microsoft.com/fr-fr/library/microsoft.visualbasic.fileio.textfieldparser.commenttokens (v=vs.110).aspx

并且: http: //geekswithblogs.net/brians/archive/2010/07/07/whats-a-nice-class-like-textfieldparser-doing-in-a-namespace.aspx

于 2014-02-07T10:48:58.077 回答
0

如果内存空间不是问题。首先加载 CSV 行列表,然后解析每一行保存最后一行。否则,您需要某种方式来识别汇总行。(例如日期之类的空数据)可以指示解析器忽略该行。

处理导入数据的最佳方法是尝试确定导入文件将仅包含要导入的数据。(没有标题,没有摘要等)不幸的是,很多公司尝试导入报告而不是实际的导出文件。

于 2012-08-16T06:24:23.893 回答
0

如果您有许多不同的情况需要识别摘要行和内存空间是一个问题,您始终可以使用以下TextFieldParser.PeekChars(Int32)方法:

读取指定数量的字符而不推进光标。

在备注部分:

numberOfChars 值必须小于该行中的字符总数。如果不是,PeekChars 返回的字符串将被截断为行的长度。

为此:

TextFieldParser parser = new TextFieldParser(file); 
//single file 
//TextFieldParser parser = new TextFieldParser(CSVFolderPath + "\\" + file); 
parser.TextFieldType = FieldType.Delimited; 
parser.SetDelimiters(","); 
int k = 0; 
while (!parser.EndOfData) 
{ 
    //Processing row 
    string[] fields = parser.ReadFields();

    //Peek if this is the last line, then break
    if (parser.PeekChars(Int32.MaxValue) is "") break;

    if (k != 0) 
    { 
...

docs.microsoft链接

于 2019-08-28T18:47:18.470 回答