From 73967a99d879e2f4622e8b468a17ddcd683584c7 Mon Sep 17 00:00:00 2001 From: yangle <admin@YINMOU> Date: 星期五, 29 十二月 2023 16:56:19 +0800 Subject: [PATCH] Merge branch 'master' of http://101.37.171.70:10101/r/MES-WEB-API --- WebAPI/Controllers/BLL/Xt_UserController.cs | 246 +++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 245 insertions(+), 1 deletions(-) diff --git a/WebAPI/Controllers/BLL/Xt_UserController.cs b/WebAPI/Controllers/BLL/Xt_UserController.cs index 706ab8f..fdc78b8 100644 --- a/WebAPI/Controllers/BLL/Xt_UserController.cs +++ b/WebAPI/Controllers/BLL/Xt_UserController.cs @@ -1505,8 +1505,252 @@ } } #endregion + #region 鐢ㄦ埛鍏宠仈瀹㈡埛 鏂囦欢涓婁紶 + [Route("Xt_User/Gy_UserCustomer_ImportByExcel")] + [HttpPost] + public object Gy_UserCustomer_ImportByExcel() + { + try + { + //var WorkBookName = HttpContext.Current.Request["WorkBookName"]; + //DBUtility.ClsPub.HOrgID = long.Parse(HttpContext.Current.Request["HOrgID"]); + //鑾峰彇鏂囦欢鍚嶇О + var file = HttpContext.Current.Request.Files[0]; + //鑾峰彇鏂囦欢鐗╃悊璺緞 + string ExcelPath = HttpContext.Current.Server.MapPath("~/" + file.FileName); + //淇濆瓨鏂囦欢 + file.SaveAs(ExcelPath); - #region 鐢ㄦ埛鍏宠仈鐗╂枡淇濆瓨 + NpoiHelper np = new NpoiHelper(); + DataSet ExcelDs = np.ReadExcel(ExcelPath, 1, 1, "0"); + + //鍒犻櫎鏂囦欢 + File.Delete(ExcelPath); + + //鍒涘缓涓存椂琛� + DataTable tb2 = new DataTable("dt2"); + + //娣诲姞鍒楀悕 + for (int i = 0; i < ExcelDs.Tables[0].Columns.Count; i++) + { + tb2.Columns.Add(ExcelDs.Tables[0].Rows[0][i].ToString()); + } + + //妯℃澘缂哄皯鍒� 浣嗛渶瑕佷粠鏁版嵁搴撲腑鏌ヨ鍑烘潵鏄剧ず鍦ㄩ〉闈㈢殑瀛楁 + tb2.Columns.Add("HCusID", typeof(Int32));//缁勭粐ID + tb2.Columns.Add("HUserID", typeof(Int32));//渚涘簲鍟� + + //娣诲姞鏁版嵁 + for (int i = 1; i < ExcelDs.Tables[0].Rows.Count; i++) + { + DataRow row = tb2.NewRow(); + for (int j = 0; j < ExcelDs.Tables[0].Columns.Count; j++) + { + row[j] = ExcelDs.Tables[0].Rows[i][j].ToString(); + } + tb2.Rows.Add(row); + } + + //鏌ヨExcel鏂囦欢涓病鏈夌殑鍒� + var error = ""; + if (!tb2.Columns.Contains("瀹㈡埛浠g爜")) + { + error += "娌℃湁鎵惧埌銆愬鎴蜂唬鐮併�戠殑鏍囬,"; + } + if (!tb2.Columns.Contains("瀹㈡埛鍚嶇О")) + { + error += "娌℃湁鎵惧埌銆愬鎴峰悕绉般�戠殑鏍囬,"; + } + if (!tb2.Columns.Contains("鐢ㄦ埛鍚嶇О")) + { + error += "娌℃湁鎵惧埌銆愮敤鎴峰悕绉般�戠殑鏍囬,"; + } + if (error.Length > 0) + { + objJsonResult.code = "0"; + objJsonResult.count = 0; + objJsonResult.Message = $"Excel妯℃澘瀛樺湪閿欒,{error}\r\n"; + objJsonResult.data = null; + return objJsonResult; + } + + //鏌ヨ鏁版嵁璧嬬粰鏁版嵁琛� + string err = ""; + for (int i = 0; i <= tb2.Rows.Count - 1; i++) + { + string HCusNumber = DBUtility.ClsPub.isStrNull(tb2.Rows[i]["瀹㈡埛浠g爜"].ToString()); + string HCusName = DBUtility.ClsPub.isStrNull(tb2.Rows[i]["瀹㈡埛鍚嶇О"].ToString()); + string HUserName = DBUtility.ClsPub.isStrNull(tb2.Rows[i]["鐢ㄦ埛鍚嶇О"].ToString()); + int index = i + 1; + string sql = ""; + if (HCusNumber != "" && HUserName != "") + { + //鑾峰彇瀹㈡埛鍐呯爜 + sql = "select * from Gy_Customer where HNumber = '" + HCusNumber + "'"; + string HCusID = "0"; + ds = oCN.RunProcReturn(sql, "Gy_Customer"); + if (ds.Tables[0].Rows.Count == 0) + { + err += "绗�" + index + "琛�,瀹㈡埛涓嶅瓨鍦�!"; + continue; + } + else + { + tb2.Rows[i]["HCusID"] = ds.Tables[0].Rows[0]["HItemID"].ToString(); + HCusID = ds.Tables[0].Rows[0]["HItemID"].ToString(); + } + + //鑾峰彇鐢ㄦ埛鍐呯爜 + sql = "select * from Gy_Czygl where Czymc = '" + HUserName + "'"; + string HUserID = ""; + ds = oCN.RunProcReturn(sql, "Gy_Czygl"); + if (ds.Tables[0].Rows.Count == 0) + { + err += "绗�" + index + "琛�,鐢ㄦ埛涓嶅瓨鍦�!"; + continue; + } + else + { + tb2.Rows[i]["HUserID"] = ds.Tables[0].Rows[0]["Czybm"].ToString(); + HUserID = ds.Tables[0].Rows[0]["Czybm"].ToString(); + } + + //鍒ゆ柇琛ㄤ腑鏄惁宸茬粡瀛樺湪璇ョ敤鎴峰叧鑱斿鎴� + sql = "select * from Gy_UserCustomerRelation where HCusID = " + HCusID + " and HUserID = '" + HUserID + "'"; + ds = oCN.RunProcReturn(sql, "Gy_UserCustomerRelation"); + if (ds.Tables[0].Rows.Count > 0) + { + err += "绗�" + index + "琛岋紝璇ョ敤鎴蜂笌瀹㈡埛宸茬粡鍏宠仈!"; + continue; + } + } + else + { + err += "绗�" + index + "琛�,瀹㈡埛浠g爜鎴栫敤鎴峰悕绉颁负绌�!"; + continue; + } + } + if (err.Length > 0) + { + objJsonResult.code = "0"; + objJsonResult.count = 0; + objJsonResult.Message = "瀵煎叆閿欒锛�" + err; + objJsonResult.data = null; + return objJsonResult; + } + + objJsonResult.code = "1"; + objJsonResult.count = 1; + objJsonResult.Message = error; + objJsonResult.data = tb2; + return objJsonResult; + } + catch (Exception e) + { + objJsonResult.code = "0"; + objJsonResult.count = 0; + objJsonResult.Message = "Exception锛�" + e.ToString(); + objJsonResult.data = null; + return objJsonResult; + } + } + #endregion + #region 鐢ㄦ埛鍏宠仈瀹㈡埛 瀵煎叆(淇濆瓨) + [Route("Xt_User/Gy_UserCustomer_ImportByExcel_Save")] + [HttpPost] + public object Gy_UserCustomer_ImportByExcel_Save([FromBody] JObject sMainSub) + { + var _value = sMainSub["sMainSub"].ToString(); + string msg1 = _value.ToString(); + string[] sArray = msg1.Split(new string[] { "&鍜�" }, StringSplitOptions.RemoveEmptyEntries); + string msg2 = sArray[0].ToString(); + string user = sArray[1].ToString(); + try + { + if (!DBUtility.ClsPub.Security_Log("Gy_UserRelationCustomer_Edit", 1, false, user)) + { + objJsonResult.code = "0"; + objJsonResult.count = 0; + objJsonResult.Message = "鏃犲鍏ユ潈闄愶紒"; + objJsonResult.data = null; + return objJsonResult; + } + + List<object> Excel = Newtonsoft.Json.JsonConvert.DeserializeObject<List<object>>(msg2); + List<Dictionary<string, string>> list = new List<Dictionary<string, string>>(); + + foreach (JObject item in Excel) + { + Dictionary<string, string> dic = new Dictionary<string, string>(); + foreach (var itm in item.Properties()) + { + dic.Add(itm.Name, itm.Value.ToString()); + } + list.Add(dic); + } + + oCN.BeginTran(); + string err = ""; + int i = 1; + string sql = ""; + foreach (Dictionary<string, string> item in list) + { + string HUserID = item["HUserID"].ToString();//渚涘簲鍟� + string HUserName = item["鐢ㄦ埛鍚嶇О"].ToString();//鐗╂枡ID + string HCusID = item["HCusID"].ToString();//缁勭粐ID + string HCusNumber = item["瀹㈡埛浠g爜"].ToString(); + string HCusName = item["瀹㈡埛鍚嶇О"].ToString(); + + sql = "select * from Gy_UserCustomerRelation where HUserID = '" + HUserID + "' and HCusID = " + HCusID; + ds = oCN.RunProcReturn(sql, "Gy_UserCustomerRelation"); + if (ds.Tables[0].Rows.Count == 0) + { + sql = "insert into Gy_UserCustomerRelation(HUserID,HCusID)" + + "values(" + + "'" + HUserID + "'" + + "," + HCusID + "" + + ")"; + oCN.RunProc(sql); + } + else + { + err += "绗�" + i + "琛岋細鐢ㄦ埛宸茬粡鍏宠仈璇ュ鎴�!"; + } + i++; + } + //鍒ゆ柇鏄惁瀛樺湪閿欒 + if (err.Length > 0) + { + oCN.RollBack(); + objJsonResult.code = "0"; + objJsonResult.count = 0; + objJsonResult.Message = "瀵煎叆閿欒锛�"+ err; + objJsonResult.data = null; + return objJsonResult; + } + + oCN.Commit(); + objJsonResult.code = "1"; + objJsonResult.count = 1; + objJsonResult.Message = "瀵煎叆鎴愬姛!"; + objJsonResult.data = null; + return objJsonResult; + } + catch (Exception e) + { + LogService.Write(e); + oCN.RollBack(); + objJsonResult.code = "0"; + objJsonResult.count = 0; + objJsonResult.Message = "Exception锛�" + e.ToString(); + objJsonResult.data = null; + return objJsonResult; + } + } + #endregion + + + #region 鐢ㄦ埛鍏宠仈瀹㈡埛淇濆瓨 [Route("Xt_User/SaveUserCustomer")] [HttpPost] public object SaveUserCustomer([FromBody] JObject msg) -- Gitblit v1.9.1