ArrayToDataTable

public static DataTable Convert(string strFileds, List txt,string strFileName, string strMC_NO, ref Grenarate_XML xml )
{
DataTable dt = new DataTable();

            string[] colArr = strFileds.Split(new string[] { "," }, StringSplitOptions.None);
            foreach (string ColumnName in colArr)
            {
                dt.Columns.Add(ColumnName, typeof(string));
            } 

            string strNextLine = ""; 
            int Record = -1;
            int csvCount =0;
            string str=""; 

            for (int i = 0; i < txt.Count; i++)
            {
                strNextLine = txt[i].ToString().Replace(" ", ";");

                string[] sArr = strNextLine.Split(new string[] { ";" }, StringSplitOptions.None);

                DataRow dr = dt.NewRow();
                for (int j = 0; j < dt.Columns.Count; j++)  // 只取 配置长度
                {
                    if (j == 0)
                    {
                        dr[j] = System.DateTime.Now.ToString();
                    }
                    if (j == 1)
                    {
                        dr[j] = strMC_NO;
                    }
                    else
                    {
                        int n = 0;

                        if (j > 1)
                        {
                            n = j - 2;
                        }
                        dr[j] = sArr[n].ToString();
                    } 
                } 

                //str = dr[5].ToString() + "," + dr[6].ToString() + "," + dr[10].ToString();    //DATETIMELS_Date,DATETIMELS_Time,PANELS
                str = dr[6].ToString() + "," + dr[7].ToString() + "," + dr[11].ToString();    //DATETIMELS_Date,DATETIMELS_Time,PANELS

                if (xml.last_Line.ToString() != "")
                {
                    if (Record >= 0)
                    {
                        Record++; 
                        dt.Rows.Add(dr);
                    }
                    else
                    {
                       if (xml.last_Line == str)
                        {
                            Record = 0;
                        }
                    } 
                }
                else
                {
                    Record++;
                    dt.Rows.Add(dr);
                }

                if (Record == 1)
                {
                    xml.first_Line = str;  //更新取第一条记录
                }

                csvCount ++;
            }

            if (str != string.Empty)
            {
                xml.last_Line = str;  //更新最后一条记录
            }
            xml.record = "CSV_Record: " + csvCount.ToString() + "," + "Pass_Record: " + Record.ToString();

            return dt;
        }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值