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; case fEquipment.eTabletype.ING: dt = new dsEQ.EETGW_EquipmentIngDataTable(); 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 datas = new List(); 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 cols = new List(); 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("실행 하려면 '예' 를 누르세요"); 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; //기존자료삭제코드 dlg = FCOMMON.Util.MsgQ("기존에 등록된 자료를 삭제할까요?\n자료를 추가하려면 아니오를 클릭하세요"); if (dlg == DialogResult.Yes) { switch (imptype) { case fEquipment.eTabletype.MOLD: var taE = new dsEQTableAdapters.EquipmentMETableAdapter(); taE.DeleteData(dateStr); break; case fEquipment.eTabletype.BUMP: var taB = new dsEQTableAdapters.EquipmentBTableAdapter(); taB.DeleteData(dateStr); break; case fEquipment.eTabletype.FOL: var taF = new dsEQTableAdapters.EquipmentFTableAdapter(); taF.DeleteData(dateStr); break; case fEquipment.eTabletype.ING: var taI = new dsEQTableAdapters.EETGW_EquipmentIngTableAdapter(); taI.DeleteData(dateStr); break; } } //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 rcsflag = dr[1].ToString(); if (rcsflag != "M") continue; //없는 라인코드는 추가 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; case fEquipment.eTabletype.ING: var taI = new dsEQTableAdapters.EETGW_EquipmentIngTableAdapter(); //taI.DeleteData(dateStr); taI.Update((dsEQ.EETGW_EquipmentIngDataTable)dt); break; } dt.AcceptChanges(); FCOMMON.Util.MsgI("Save OK"); } } }