如何在导入之前验证CSV文件行

时间:2017-05-02 04:02:19

标签: c# .net asp.net-mvc entity-framework

我有以下平面文件:

https://www.screencast.com/t/42mFZIrB04b

正如您所看到的那样,ROW显然没有正确格式化。

我有以下代码:

 public class FlatFileModel
    {
        public string Key { get; set; }
        public string ArticleNumber { get; set; }
        public string ColorCode { get; set; }
        public string Description { get; set; }
        public string Price { get; set; }
        public string ActionPrice { get; set; }
        public string Delivery { get; set; }
        public string Q1 { get; set; }
        public string Size { get; set; }
        public string Color { get; set; }
    }




[HttpPost]
        public ActionResult Upload()
        {
            if (Request.Files.Count > 0)
            {
                var httpPostedFileBase = Request.Files[0];
                if (httpPostedFileBase != null && httpPostedFileBase.ContentLength > 0)
                {
                    //read data from input stream
                    using (var csvReader = new System.IO.StreamReader(httpPostedFileBase.InputStream))
                    {
                        string inputLine = "";

                        List<FlatFileModel> lineaArchivo = new  List<FlatFileModel>();
                        //read each line
                        while ((inputLine = csvReader.ReadLine()) != null)
                        {
                            //get lines values
                            string[] values = inputLine.Split(new char[] { ',' });

                            for (int x = 0; x < values.Length; x++)
                            {
                                lineaArchivo.Add(new FlatFileModel()
                                {
                                    Key = values[0],
                                    ArticleNumber = values[1],
                                    ColorCode = values[2],
                                    Description = values[3],
                                    Price = values[4],
                                    ActionPrice = values[5],
                                    Delivery = values[6],
                                    Q1 = values[7],
                                    Size = values[8],
                                    Color = values[9]
                                });
                            }
                        }

                        csvReader.Close();
                    }
                }
                //var file = Request.Files[0];

                //if (file != null && file.ContentLength > 0)
                //{
                //    var fileName = Path.GetFileName(file.FileName);
                //    var path = Path.Combine(Server.MapPath("~/CSVs/"), fileName);
                //    file.SaveAs(path);
                //}
            }

            return RedirectToAction("Index");
        }

我需要一种简单的方法来检测不适合格式的ROWS,所以我可以忽略它们,或者将它们记录为错误,但我不知道我该怎么做。

由于

2 个答案:

答案 0 :(得分:1)

由于所有内容都是字符串,因此您只需检查实际读取的行中是否有正确数量的元素。

if (values.Length == 10) {
    // row ok, do your for-loop
}

答案 1 :(得分:1)

关于如何验证数据,一个好方法是考虑什么构成有效行与无效行,然后编纂这些规则。

然后,您可以使用它来构建一个正则表达式语句,用于标识不适合该模式的行。

例如,您可以检查每个字段是否匹配适当的模式(每行的第2列应包含整数,第5列应包含2位十进制值,第6列不应包含任何内容,第9列应包含整数等等。)