在 CSV 文件导入期间验证列顺序

本文关键字:验证 顺序 导入期 CSV 文件 | 更新日期: 2023-09-27 18:37:01

我的公司有客户线索的CSV文件,需要导入到我们的CRM中。我需要导入的 CSV 文件列按此顺序排列,然后才能成功导入。在某些情况下,如果用户未正确设置列的格式,则可能会发生用户错误,并且"名字"可能会排在第一位。为了防止以这种方式导入整个文件,我需要检查并查看所有列是否按此顺序匹配:

  1. 公司名称
  2. 名字
  3. 职称
  4. 电子邮件
  5. 街道地址
  6. 城市
  7. 邮编
  8. 电话
  9. 移动
  10. 传真
  11. 网址

到目前为止,我所拥有的并没有正确验证公司名称是否首先出现,而是将 CSV 中的任何 A 列保存为公司名称。我已经尝试了很多类似的事情,但没有运气。我找不到编写代码背后的逻辑。注意:我写的内容没有读取列标题,我确信这就是我的问题所在。

控制器:

         [HttpPost]
     public ActionResult LeadProcessImport(HttpPostedFileBase FileUpload)
     {
         DataTable dt = new DataTable();
         if (FileUpload == null)
         {
             TempData["Message"] = "";
             return View();
         }

         string ext = Path.GetExtension(FileUpload.FileName);
         if (FileUpload.ContentLength > 0)
         {
             string fileName = Path.GetFileName(FileUpload.FileName);
             string path = Path.Combine(Server.MapPath("~/Content/images"), fileName);

             try
             {
                 FileUpload.SaveAs(path);
                 dt = ProcessCSV(path);
                 foreach (DataRow row in dt.Rows)
                 {
                     Lead leadImport = new Lead();
                     // order I need columns to appear in CSV
                     // 
                     leadImport.CompanyName = row[0].ToString();
                     leadImport.FirstName = row[1].ToString();
                     leadImport.LastName = row[2].ToString();
                     leadImport.Title = row[3].ToString();
                     leadImport.Email = row[4].ToString();
                     leadImport.StreetAddress = row[5].ToString();
                     leadImport.City = row[6].ToString();
                     leadImport.State_Province = row[7].ToString();
                     leadImport.Zip_PostalCode = row[8].ToString();
                     leadImport.Phone = row[9].ToString();
                     leadImport.Mobile = row[10].ToString();
                     leadImport.Fax = row[11].ToString();
                     leadImport.WebURL = row[12].ToString();
                     leadImport.LeadSource = 1;
                     leadImport.LeadStatus = 2;
                     // If string "Company Name" in header does not appear
                     // first, dump the Datatable and return to different page
                     // no workie
                     if (leadImport.CompanyName != row[0].ToString())
                     {
                         dt.Dispose();
                         return Redirect(Url.Action("LeadProcess"));
                     }
                     else
                         // if all columns are in correct order, carry on
                         // with the import
                     {
                         db.Leads.Add(leadImport);
                     }

                 }
                 db.SaveChanges();
             }
             catch (Exception ex)
             {
                 ViewData["Feedback"] = ex.Message;
             }
         }
         else
         {
             ViewData["Feedback"] = "Please select a file";
         }
         dt.Dispose();
         return Redirect(Url.Action("Index"));
     }

在 CSV 文件导入期间验证列顺序

如果你正在解析CSV,我建议你使用像CsvHelper这样的工具。我们一直在使用它来完成非常相似的任务。它具有各种令人敬畏的配置。

var csvConfiguration = new CsvConfiguration
{
    Quote = '"',
    Delimiter = ",",
    TrimFields = true,
    TrimHeaders = true,
    QuoteNoFields = false,
    QuoteAllFields = false,
    HasHeaderRecord = true,
    IsHeaderCaseSensitive = false,
    WillThrowOnMissingField = false
};
var field = csvReader.GetField("YourFieldName"),

它还具有非常好的映射功能