我有以下平面文件:
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,所以我可以忽略它们,或者将它们记录为错误,但我不知道我该怎么做。
由于
答案 0 :(得分:1)
由于所有内容都是字符串,因此您只需检查实际读取的行中是否有正确数量的元素。
if (values.Length == 10) {
// row ok, do your for-loop
}
答案 1 :(得分:1)
关于如何验证数据,一个好方法是考虑什么构成有效行与无效行,然后编纂这些规则。
然后,您可以使用它来构建一个正则表达式语句,用于标识不适合该模式的行。
例如,您可以检查每个字段是否匹配适当的模式(每行的第2列应包含整数,第5列应包含2位十进制值,第6列不应包含任何内容,第9列应包含整数等等。)