在 CSV 文件导入期间验证列顺序
本文关键字:验证 顺序 导入期 CSV 文件 | 更新日期: 2023-09-27 18:37:01
我的公司有客户线索的CSV文件,需要导入到我们的CRM中。我需要导入的 CSV 文件列按此顺序排列,然后才能成功导入。在某些情况下,如果用户未正确设置列的格式,则可能会发生用户错误,并且"名字"可能会排在第一位。为了防止以这种方式导入整个文件,我需要检查并查看所有列是否按此顺序匹配:
- 公司名称
- 名字
- 姓
- 职称
- 电子邮件
- 街道地址
- 城市
- 州
- 邮编
- 电话
- 移动
- 传真
- 网址
到目前为止,我所拥有的并没有正确验证公司名称是否首先出现,而是将 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,我建议你使用像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"),
它还具有非常好的映射功能