누락파일추가
This commit is contained in:
		
							
								
								
									
										354
									
								
								SubProject/FEQ0000/Equipment/fImpEquipment.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										354
									
								
								SubProject/FEQ0000/Equipment/fImpEquipment.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,354 @@ | ||||
| using System; | ||||
| using System.Collections.Generic; | ||||
| using System.ComponentModel; | ||||
| using System.Data; | ||||
| using System.Drawing; | ||||
| using System.Linq; | ||||
| using System.Text; | ||||
| using System.Windows.Forms; | ||||
|  | ||||
| namespace FEQ0000 | ||||
| { | ||||
|     public partial class fImpEquipment : Form | ||||
|     { | ||||
|         DataTable dt = null; | ||||
|         DataTable dtExcel = new DataTable(); | ||||
|         fEquipment.eTabletype imptype = fEquipment.eTabletype.MOLD; | ||||
|         public fImpEquipment(fEquipment.eTabletype type_) | ||||
|         { | ||||
|             InitializeComponent(); | ||||
|             this.FormClosed += __Closed; | ||||
|             imptype = type_; | ||||
|  | ||||
|             switch (imptype) | ||||
|             { | ||||
|                 case fEquipment.eTabletype.FOL: | ||||
|                     dt = new dsEQ.EquipmentFDataTable(); | ||||
|                     break; | ||||
|                 case fEquipment.eTabletype.MOLD: | ||||
|                     dt = new dsEQ.EquipmentMEDataTable(); | ||||
|                     break; | ||||
|                 case fEquipment.eTabletype.BUMP: | ||||
|                     dt = new dsEQ.EquipmentBDataTable(); | ||||
|                     break; | ||||
|  | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         private void __Load(object sender, EventArgs e) | ||||
|         { | ||||
|             this.Text = string.Format("Data Import({0})", this.imptype); | ||||
|             var form = this as Form; | ||||
|             FCOMMON.Util.SetFormStatus(ref form, this.Name, true); | ||||
|             this.Show(); | ||||
|             Application.DoEvents(); | ||||
|         } | ||||
|  | ||||
|         void __Closed(object sender, FormClosedEventArgs e) | ||||
|         { | ||||
|             var form = this as Form; | ||||
|             FCOMMON.Util.SetFormStatus(ref form, this.Name, false); | ||||
|         } | ||||
|  | ||||
|         private void linkLabel1_LinkClicked(object sender, LinkLabelLinkClickedEventArgs e) | ||||
|         { | ||||
|             OpenFileDialog od = new OpenFileDialog(); | ||||
|             od.Filter = "excel|*.xlsx|all files|*.*"; | ||||
|             od.InitialDirectory = FCOMMON.Util.CurrentPath + "model"; | ||||
|             od.FilterIndex = 1; | ||||
|             od.RestoreDirectory = true; | ||||
|             if (od.ShowDialog() != System.Windows.Forms.DialogResult.OK) return; | ||||
|             textBox1.Text = od.FileName; | ||||
|         } | ||||
|  | ||||
|         private string[] getCSVFormat(string line) | ||||
|         { | ||||
|             List<string> datas = new List<string>(); | ||||
|             var charlist = line.ToCharArray(); | ||||
|             int c = 0; | ||||
|             System.Text.StringBuilder sb = new StringBuilder(); | ||||
|             Boolean findCom = false; | ||||
|             foreach (var ch in charlist) | ||||
|             { | ||||
|                 if (ch == '"') | ||||
|                 { | ||||
|                     if (findCom == false) | ||||
|                         findCom = true; | ||||
|                     else findCom = false; | ||||
|                 } | ||||
|                 else if (ch == ',') | ||||
|                 { | ||||
|                     if (findCom) | ||||
|                     { | ||||
|                         sb.Append(ch); | ||||
|                     } | ||||
|                     else | ||||
|                     { | ||||
|                         datas.Add(sb.ToString()); | ||||
|                         sb.Clear(); | ||||
|                         findCom = false; | ||||
|                     } | ||||
|  | ||||
|                 } | ||||
|                 else sb.Append(ch); | ||||
|             } | ||||
|             return datas.ToArray(); | ||||
|         } | ||||
|         private void button1_Click(object sender, EventArgs e) | ||||
|         { | ||||
|             if(textBox1.Text.isEmpty()) | ||||
|             { | ||||
|                 FCOMMON.Util.MsgE("파일을 선택하세요"); | ||||
|                 textBox1.Focus(); | ||||
|                 return; | ||||
|             } | ||||
|             if(!System.IO.File.Exists(textBox1.Text)) | ||||
|             { | ||||
|                 FCOMMON.Util.MsgE("입력하신 파일이 존재하지 않습니다."); | ||||
|                 textBox1.Focus(); | ||||
|                 textBox1.SelectAll(); | ||||
|                 return; | ||||
|             } | ||||
|  | ||||
|             dtExcel.Columns.Clear(); | ||||
|             dtExcel.Rows.Clear(); | ||||
|             dtExcel.AcceptChanges(); | ||||
|              | ||||
|             libxl.Book book;// = new libxl.BinBook(); | ||||
|             book = new libxl.XmlBook(); | ||||
|             book.setKey(FCOMMON.info.libxlCompany, FCOMMON.info.libxlKey); | ||||
|             try | ||||
|             { | ||||
|                 book.load(textBox1.Text); | ||||
|             }catch (Exception ex) | ||||
|             { | ||||
|                 FCOMMON.Util.MsgE(ex.Message); | ||||
|                 return; | ||||
|             } | ||||
|  | ||||
|             int sheetNum = (int)numericUpDown1.Value; | ||||
|             if (sheetNum >= book.sheetCount()) | ||||
|             { | ||||
|                 FCOMMON.Util.MsgE("입력한 시트 번호는 존재하지 않습니다."); | ||||
|                 book = null; | ||||
|                 return; | ||||
|             } | ||||
|             var sheet = book.getSheet(sheetNum); | ||||
|             var MaxRow = sheet.lastRow(); | ||||
|             var MinRow = sheet.firstRow(); | ||||
|             var MaxCol = sheet.lastCol(); | ||||
|             var MinCol = sheet.firstCol(); | ||||
|             List<string> cols = new List<string>(); | ||||
|             bool firstRow = true; | ||||
|             try{ | ||||
|                 for (int r = MinRow; r <= MaxRow; r++) | ||||
|                 { | ||||
|                     DataRow dr = null; | ||||
|                     if (firstRow ==false) dr = dtExcel.NewRow(); | ||||
|  | ||||
|                     Boolean nullColumn = false; | ||||
|                     for (int c = MinCol; c <= MaxCol; c++) | ||||
|                     { | ||||
|                         var strVallue = sheet.readStr(r, c); | ||||
|                         if (strVallue.isEmpty() && c == MinCol) | ||||
|                         { | ||||
|                             //첫줄 첫행이 빈값이면 처리하지 않는다. | ||||
|                             nullColumn = true; | ||||
|                             break; | ||||
|                         } | ||||
|                         if (firstRow) | ||||
|                         { | ||||
|                             cols.Add(strVallue); | ||||
|                             this.dtExcel.Columns.Add(strVallue); | ||||
|                         } | ||||
|                         else | ||||
|                         { | ||||
|                             if (!cols[c].isEmpty()) | ||||
|                                 dr[cols[c]] = strVallue; | ||||
|                         } | ||||
|                     } | ||||
|                     if (nullColumn) continue; //줄처리를 못한 경우 넘어감 | ||||
|                     if (firstRow) firstRow = false; | ||||
|                     if (dr != null) dtExcel.Rows.Add(dr); | ||||
|                 } | ||||
|                 dtExcel.AcceptChanges(); | ||||
|             } | ||||
|            catch(Exception ex) | ||||
|             { | ||||
|                 FCOMMON.Util.MsgE("불러오는 중 오류 발생\n" + ex.Message); | ||||
|             } | ||||
|             // | ||||
|             book = null; | ||||
|  | ||||
|             this.bs.DataSource = dtExcel; | ||||
|             this.dataGridView1.DataSource = dtExcel; | ||||
|             this.bn.BindingSource = this.bs; | ||||
|  | ||||
|             if(this.bs.Count < 1) | ||||
|             { | ||||
|                 FCOMMON.Util.MsgE("입력된 자료가 없습니다.\n\n지정된 엑셀의 1번째 칸에 값이 없다면 입력되지 않습니다."); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         private void button2_Click(object sender, EventArgs e) | ||||
|         { | ||||
|             var ta = new dsEQTableAdapters.LineCodeTableAdapter(); | ||||
|             var lineTd = ta.GetData(); | ||||
|             lineTd.AcceptChanges(); | ||||
|             //12,13 | ||||
|             foreach (DataRow dr in dt.Rows) | ||||
|             { | ||||
|                 var linecode = dr[12].ToString(); | ||||
|                 var linedesc = dr[13].ToString(); | ||||
|                 var codeDrows = lineTd.Select("code='" + linecode + "'"); | ||||
|                 if (codeDrows.Length == 0) | ||||
|                 { | ||||
|                     var newdr = lineTd.NewLineCodeRow(); | ||||
|                     newdr.code = linecode; | ||||
|                     newdr.memo = linedesc; | ||||
|                     var linebuf = linedesc.Split('-'); | ||||
|                     if (linebuf.Length > 1) | ||||
|                     { | ||||
|                         newdr.team = linebuf[0]; | ||||
|                         newdr.part = linebuf[1]; | ||||
|                     } | ||||
|                     else | ||||
|                     { | ||||
|                         newdr.team = linedesc; | ||||
|                     } | ||||
|  | ||||
|                     newdr.wuid = FCOMMON.info.Login.no; | ||||
|                     newdr.wdate = DateTime.Now; | ||||
|                     lineTd.AddLineCodeRow(newdr); | ||||
|                 } | ||||
|             } | ||||
|             ta.Update(lineTd); | ||||
|             lineTd.AcceptChanges(); | ||||
|             FCOMMON.Util.MsgE("test"); | ||||
|  | ||||
|         } | ||||
|  | ||||
|         private void button3_Click(object sender, EventArgs e) | ||||
|         { | ||||
|             if(dtExcel == null || dtExcel.Rows.Count < 1) | ||||
|             { | ||||
|                 FCOMMON.Util.MsgE("등록 가능한 자료가 없습니다."); | ||||
|                 return; | ||||
|             } | ||||
|  | ||||
|             System.Text.StringBuilder sb = new StringBuilder(); | ||||
|             sb.AppendLine("다음 자료를 추가하시겠습니까?"); | ||||
|             sb.AppendLine(); | ||||
|             sb.AppendLine("등록일 : " + dateTimePicker1.Value.ToShortDateString()); | ||||
|             sb.AppendLine(); | ||||
|             sb.AppendLine("해당 일자에 등록된 자료가 있다면 삭제 됩니다."); | ||||
|             sb.AppendLine("'저장 완료' 메세지가 나올때 까지 기다려 주세요."); | ||||
|             sb.AppendLine(); | ||||
|             sb.AppendLine("실행 하려면 '예' 를 누르세요"); | ||||
|             var dlg = FCOMMON.Util.MsgQ(sb.ToString()); | ||||
|             if (dlg != System.Windows.Forms.DialogResult.Yes) return; | ||||
|              | ||||
|             //라인코드를 읽어서 값을 기록해준다. | ||||
|             var taLine = new  dsEQTableAdapters.LineCodeTableAdapter(); | ||||
|             var lineTd = taLine.GetData(); | ||||
|             lineTd.AcceptChanges(); | ||||
|  | ||||
|             dt.Clear(); | ||||
|             dt.AcceptChanges(); | ||||
|  | ||||
|             var dateStr = this.dateTimePicker1.Value.ToShortDateString(); | ||||
|             this.progressBar1.Value = 0; | ||||
|             this.progressBar1.Maximum = dtExcel.Rows.Count; | ||||
|  | ||||
|             //12,13 | ||||
|             foreach (DataRow dr in dtExcel.Rows) | ||||
|             { | ||||
|                 this.progressBar1.Value += 1; | ||||
|  | ||||
|                 var linecode = dr[12].ToString(); | ||||
|                 var linedesc = dr[13].ToString(); | ||||
|                 var lineT = string.Empty; | ||||
|                 var lineP = string.Empty; | ||||
|  | ||||
|                 //없는 라인코드는 추가 | ||||
|                 var lineDrows = lineTd.Select("code='" + linecode + "'"); | ||||
|                 if (lineDrows.Length == 0) | ||||
|                 { | ||||
|                     var linebuf = linedesc.Split('-'); | ||||
|                     if (linebuf.Length > 1) | ||||
|                     { | ||||
|                         lineT = linebuf[0]; | ||||
|                         lineP = linebuf[1]; | ||||
|                     } | ||||
|                     else | ||||
|                     { | ||||
|                         lineT = linedesc; | ||||
|                         lineP = string.Empty; | ||||
|                     } | ||||
|  | ||||
|  | ||||
|                     var newli = lineTd.NewLineCodeRow(); | ||||
|                     newli.code = linecode; | ||||
|                     newli.team = lineT; | ||||
|                     newli.part = lineP; | ||||
|                     newli.memo = linedesc; | ||||
|                     newli.except = false; | ||||
|                     newli.wuid = FCOMMON.info.Login.no; | ||||
|                     newli.wdate = DateTime.Now; | ||||
|                     lineTd.AddLineCodeRow(newli); | ||||
|                 } | ||||
|                 else | ||||
|                 { | ||||
|                     var lineDr = lineDrows[0] as dsEQ.LineCodeRow; | ||||
|                     lineT = lineDr.team; | ||||
|                     lineP = lineDr.part; | ||||
|                 } | ||||
|  | ||||
|                 //데이터추가 | ||||
|                 var newdr = dt.NewRow(); | ||||
|                 newdr["pdate"] = dateTimePicker1.Value.ToShortDateString(); | ||||
|                 newdr["asset"] = dr[6].ToString(); | ||||
|                 newdr["grp"] = dr[0].ToString(); | ||||
|                 newdr["type"] = dr[2].ToString(); | ||||
|                 newdr["model"] = dr[3].ToString(); | ||||
|                 newdr["linecode"] = linecode; | ||||
|                 newdr["lineT"] = lineT; | ||||
|                 newdr["lineP"] = lineP; | ||||
|                 newdr["serial"] = dr[7].ToString(); | ||||
|                 newdr["manu"] = dr[9].ToString(); | ||||
|                 newdr["primary"] = true; | ||||
|                 newdr["wuid"] = FCOMMON.info.Login.no; | ||||
|                 newdr["wdate"] = DateTime.Now; | ||||
|                 newdr["except"] = false; | ||||
|                 newdr["memo"] = string.Empty; | ||||
|                 if (imptype == fEquipment.eTabletype.BUMP) newdr["param1"] = "8\""; | ||||
|                 else newdr["param1"] = string.Empty; | ||||
|                 dt.Rows.Add(newdr); | ||||
|             } | ||||
|  | ||||
|             taLine.Update(lineTd); | ||||
|             lineTd.AcceptChanges(); | ||||
|  | ||||
|             switch (imptype) | ||||
|             { | ||||
|                 case fEquipment.eTabletype.MOLD: | ||||
|                     var taE = new dsEQTableAdapters.EquipmentMETableAdapter(); | ||||
|                     taE.DeleteData(dateStr); | ||||
|                     taE.Update((dsEQ.EquipmentMEDataTable)dt); | ||||
|                     break; | ||||
|                 case fEquipment.eTabletype.BUMP: | ||||
|                     var taB = new dsEQTableAdapters.EquipmentBTableAdapter(); | ||||
|                     taB.DeleteData(dateStr); | ||||
|                     taB.Update((dsEQ.EquipmentBDataTable)dt); | ||||
|                     break; | ||||
|                 case fEquipment.eTabletype.FOL: | ||||
|                     var taF = new dsEQTableAdapters.EquipmentFTableAdapter(); | ||||
|                     taF.DeleteData(dateStr); | ||||
|                     taF.Update((dsEQ.EquipmentFDataTable)dt); | ||||
|                     break; | ||||
|             } | ||||
|             dt.AcceptChanges(); | ||||
|             FCOMMON.Util.MsgI("Save OK"); | ||||
|         } | ||||
|     } | ||||
| } | ||||
		Reference in New Issue
	
	Block a user
	 chikyun.kim
					chikyun.kim