批量导入Excle数据

Posted Mark;D

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了批量导入Excle数据相关的知识,希望对你有一定的参考价值。

Controller控制器

 1 /// <summary>
 2         /// 上传模板文件
 3         /// </summary>
 4         /// <returns></returns>
 5         public ActionResult BulkInserCustomer()
 6         {
 7             HttpPostedFileBase fileData = Request.Files[0];
 8             if (fileData.ContentLength == 0)
 9             {
10                 return Json(new { result = 0, Errmsg = "请选择上传文件" });
11             }
12 
13             if (fileData.FileName != "客户人员信息导入-精简模板.xls")
14             {
15                 return Json(new { result = 0, Errmsg = "文件有误" });
16             }
17 
18             string strExtension = Path.GetExtension(fileData.FileName).ToLower();
19 
20             if (strExtension == ".xls" || strExtension == ".xlsx")
21             {
22                 double dFileSiz = fileData.ContentLength;
23                 if (dFileSiz > 1024 * 1024 * 4)
24                 {
25                     return Json(new { result = 0, Errmsg = "文件过大" });
26                 }
27 
28                 string new_fileName = Guid.NewGuid().ToString() + "_" + Path.GetFileName(fileData.FileName);
29 
30                 //哈希码解决生成多个文件夹,提高上传效率
31                 int hash_code = new_fileName.GetHashCode();
32                 int dir1 = hash_code & 0xf;
33                 hash_code = hash_code >> 4;
34                 int dir2 = hash_code & 0xf;
35 
36                 string targetFilePath = Path.Combine(Request.MapPath("~/UploadFile/BulkImport/"), dir1.ToString(), dir2.ToString());
37                 if (!Directory.Exists(targetFilePath))//文件夹不存在的时候创建
38                 {
39                     Directory.CreateDirectory(targetFilePath);
40                 }
41                 targetFilePath = Path.Combine(targetFilePath, new_fileName);//文件名与目录拼接
42                 fileData.SaveAs(targetFilePath);
43                 return Json(new { result = 1, Errmsg = targetFilePath, _fileName = fileData.FileName });
44 
45             }
46             return Json(new { result = 0, Errmsg = "文件格式错误" });
47         }
48 
49         private static List<TempMember> coopList;
50 
51         public ActionResult CheckDataResult()
52         {
53             string fileName = Request["FilePath"];
54             List<BuliImportHelp> help = null;
55             coopList = CTMBLL.CheckCustomerData(fileName, curCompanyId, curStaffLgAccID, ref help);
56 
57             return Json(new { CoopList = coopList, Help = help });
58         }
59 
60         public ActionResult BulkInsertResult()
61         {
62             int result = 0;
63             result = CTMBLL.BulkCustomerInfo(coopList);
64 
65             return Json(new { result = result });
66         }

BLL业务逻辑层

  1 /// <summary>
  2         /// 验证客户信息
  3         /// </summary>
  4         /// <param name="fileName"></param>
  5         /// <param name="companyID"></param>
  6         /// <param name="Uplist"></param>
  7         /// <returns></returns>
  8         public List<TempMember> CheckCustomerData(string fileName, long companyID, long TMAddUserId, ref List<BuliImportHelp> Uplist)
  9         {
 10             List<TempMember> list = new List<TempMember>();
 11             Uplist = new List<BuliImportHelp>();
 12             List<string> rTCNOTMPhone = new List<string>();
 13 
 14             IWorkbook workbook;
 15             using (FileStream fsRead = File.OpenRead(fileName))
 16             {
 17                 workbook = new HSSFWorkbook(fsRead);
 18                 ISheet sheet = workbook.GetSheetAt(0);
 19 
 20                 for (int r = 2; r <= sheet.LastRowNum; r++)
 21                 {
 22                     IRow currentRow = sheet.GetRow(r);
 23 
 24                     Vehicle veModel = new Vehicle();
 25                     BuliImportHelp upModel = new BuliImportHelp();
 26 
 27                     if (currentRow == null) { break; }
 28 
 29                     string TCNO = currentRow.GetCell(0) == null ? "" : currentRow.GetCell(0).ToString().Trim();
 30                     string TCShortName = currentRow.GetCell(1) == null ? "" : currentRow.GetCell(1).ToString().Trim();
 31                     string TMName = currentRow.GetCell(2) == null ? "" : currentRow.GetCell(2).ToString().Trim();
 32                     string TMPhone = currentRow.GetCell(3) == null ? "" : currentRow.GetCell(3).ToString().Trim();
 33                     var TCID = TMDAL.GetTempCompanyID(TCNO, companyID);
 34                     if (TCNO == "" && TCShortName == "" && TMName == "" && TMPhone == "") { break; }
 35 
 36                     if (TCNO == "" || TCShortName == "" || TMName == "" || TMPhone == "")
 37                     {
 38                         BuliImportHelp BuHelp = new BuliImportHelp();
 39                         BuHelp.Row = (r + 1).ToString();
 40                         BuHelp.TCNO = TCNO;
 41                         BuHelp.TCShortName = TCShortName;
 42                         BuHelp.TMName = TMName;
 43                         BuHelp.TMPhone = TMPhone;
 44                         if (TCNO == "") { BuHelp.MrrEsg = "客户编号不能为空"; }
 45                         else if (TCShortName == "") { BuHelp.MrrEsg = "客户简称不能为空"; }
 46                         else if (TMName == "") { BuHelp.MrrEsg = "成员姓名不能为空"; }
 47                         else if (TMPhone == "") { BuHelp.MrrEsg = "成员电话不能为空"; }
 48                         Uplist.Add(BuHelp);
 49                     }
 50                     else if (!UtilityHelp.isCellPhoneNumber(TMPhone))
 51                     {
 52                         BuliImportHelp BuHelp = new BuliImportHelp();
 53                         BuHelp.Row = (r + 1).ToString();
 54                         BuHelp.TCNO = TCNO;
 55                         BuHelp.TCShortName = TCShortName;
 56                         BuHelp.TMName = TMName;
 57                         BuHelp.TMPhone = TMPhone;
 58                         BuHelp.MrrEsg = "手机号码格式有误";
 59                         Uplist.Add(BuHelp);
 60                     }
 61                     else
 62                     {
 63                         bool count = true;
 64                         if (rTCNOTMPhone.IndexOf(TCNO + TMPhone) != -1)
 65                         {
 66                             BuliImportHelp BuHelp = new BuliImportHelp();
 67                             BuHelp.Row = (r + 1).ToString();
 68                             BuHelp.TCNO = TCNO;
 69                             BuHelp.TCShortName = TCShortName;
 70                             BuHelp.TMName = TMName;
 71                             BuHelp.TMPhone = TMPhone;
 72                             BuHelp.MrrEsg = "导入模板中手机号码重复";
 73                             Uplist.Add(BuHelp);
 74                             count = false;
 75                         }
 76                         else { rTCNOTMPhone.Add(TCNO + TMPhone); }
 77 
 78 
 79                         if (TCID == 0)
 80                         {
 81                             BuliImportHelp BuHelp = new BuliImportHelp();
 82                             BuHelp.Row = (r + 1).ToString();
 83                             BuHelp.TCNO = TCNO;
 84                             BuHelp.TCShortName = TCShortName;
 85                             BuHelp.TMName = TMName;
 86                             BuHelp.TMPhone = TMPhone;
 87                             BuHelp.MrrEsg = "客户编号不存在";
 88                             Uplist.Add(BuHelp);
 89                             count = false;
 90                         }
 91                         //if (TMDAL.IsExistTMPhone(TCID, TMPhone) >= 1)
 92                         //{
 93                         //    BuliImportHelp BuHelp = new BuliImportHelp();
 94                         //    BuHelp.Row = (r + 1).ToString();
 95                         //    BuHelp.TCNO = TCNO;
 96                         //    BuHelp.TCShortName = TCShortName;
 97                         //    BuHelp.TMName = TMName;
 98                         //    BuHelp.TMPhone = TMPhone;
 99                         //    BuHelp.MrrEsg = "手机号码已存在";
100                         //    Uplist.Add(BuHelp);
101                         //    count = false;
102                         //}
103                         if (count)
104                         {
105                             TempMember TM = new TempMember();
106                             TM.TMSerialNo = "";//编号生成
107                             TM.TMAddUserId = TMAddUserId;//操作人登陆ID
108                             TM.TMName = TMName;//客户成员姓名
109                             TM.TMPhone = TMPhone;//客户成员手机号
110                             TM.TMTCComID = TCID;//客户的公司ID
111                             TM.TMAddTime = DateTime.Now;//客户成员加入日期
112                             list.Add(TM);
113                         }
114                     }
115                 }
116             }
117             return list;
118         }
119 
120         /// <summary>
121         /// 批量导入客户信息
122         /// </summary>
123         /// <param name="listModel"></param>
124         /// <returns></returns>
125         public int BulkCustomerInfo(List<TempMember> listModel)
126         {
127             return TMDAL.BulkCustomerInfo(listModel);
128         }

DAL数据访问层

  1 /// <summary>
  2         /// 根据客户编号获取客户公司ID
  3         /// </summary>
  4         /// <returns></returns>
  5         public long GetTempCompanyID(string TCNO, long companyID)
  6         {
  7             string sql = @"SELECT TCID FROM TempCompany WHERE TCNO=@TCNO AND TCBelongComID = @companyID";
  8             try
  9             {
 10                 using(IDbCon)
 11                 {
 12                     long TCID = IDbCon.ExecuteScalar<long>(sql, new { TCNO = TCNO, companyID = companyID });
 13                     return TCID;
 14                 }
 15             }
 16             catch(Exception ex)
 17             {
 18                 UtilityHelp.WriteLog(ex, ex.ToString());
 19                 return 0;
 20             }
 21         }
 22 
 23         /// <summary>
 24         /// 是否存在该客户
 25         /// </summary>
 26         /// <param name="customerNum"></param>
 27         /// <param name="customerAbbreviation"></param>
 28         /// <param name="coopID"></param>
 29         /// <returns></returns>
 30         public int IsHaveCustomer(string TCNO, long companyID)
 31         {
 32             string sql = "SELECT COUNT(*) FROM TempCompany WHERE TCNO=@TCNO AND TCBelongType=1 AND TCBelongComID=@companyID";
 33 
 34 
 35             using (IDbCon)
 36             {
 37                 try
 38                 {
 39                     return IDbCon.Query<int>(sql, new
 40                     {
 41                         TCNO = TCNO,
 42                         companyID = companyID
 43                     }).FirstOrDefault();
 44                 }
 45                 catch (Exception ex)
 46                 {
 47                     UtilityHelp.WriteLog(ex, ex.ToString());
 48                     return -1;
 49                 }
 50             }
 51 
 52         }
 53 
 54         /// <summary>
 55         /// 批量导入客户人员信息
 56         /// </summary>
 57         /// <param name="listModel"></param>
 58         /// <returns></returns>
 59         public int BulkCustomerInfo(List<TempMember> listModel)
 60         {
 61             string sql = @"INSERT INTO TempMember(TMSourceCome,TMAuditState,TMIsUsable,TMTCComID,TMSerialNo,TMName,TMSex,TMPhone,TMAddUserId,TMIsPhone,TMAddTime) 
 62 VALUES(2,1,1,@TMTCComID,@TMSerialNo,@TMName,1,@TMPhone,@TMAddUserId,\'FALSE\',@TMAddTime)";
 63 
 64             int result = 0;
 65             IDbConnection iDbcon = base.IDbCon;
 66             if (iDbcon.State == ConnectionState.Closed)
 67             {
 68                 iDbcon.Open();
 69             }
 70 
 71             using (var trans = iDbcon.BeginTransaction())
 72             {
 73                 try
 74                 {
 75                     result = iDbcon.Execute(sql, listModel, trans, null, CommandType.Text);
 76                     if (result == listModel.Count())
 77                     {
 78                         trans.Commit();
 79                         return result;
 80                     }
 81                     else
 82                     {
 83                         trans.Rollback();
 84                         return 0;
 85                     }
 86                 }
 87                 catch (Exception ex)
 88                 {
 89                     trans.Rollback();
 90                     UtilityHelp.WriteLog(ex, ex.ToString());
 91                     return -1;
 92                 }
 93                 finally
 94                 {
 95                     iDbcon.Close();
 96                 }
 97             }
 98 
 99         }

BLL层需要引用NOPI

using NPOI.SS.UserModel;
using NPOI.HSSF.UserModel;

1、NuGet搜索Npoi并安装

2、添加引用将包引用进来

以上是关于批量导入Excle数据的主要内容,如果未能解决你的问题,请参考以下文章

java中怎么让导入的excle表中每一条数据对应文件夹中对应的图片

org.apache.poi3.1.7 Excle并发批量导入导出

Python-工具-批量替换EXCLE文件中某列的值

批量将制定文件夹下的全部Excel文件导入微软SQL数据库

导入excle数据将excle数据插入到数据库

Spring Boot 集成 Druid 批量插入数据和效率监控配置