3063ec5c5019c8d4d7fd4e3b72b9d2dc3e81a0e2.svn-base 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485
  1. using System;
  2. using System.Collections;
  3. using System.Collections.Generic;
  4. using System.ComponentModel;
  5. using System.Data;
  6. using System.Drawing;
  7. using System.Linq;
  8. using System.Text;
  9. using System.Windows.Forms;
  10. using CoreFS.CA06;
  11. namespace Core.LZMes.Client.UIM
  12. {
  13. public partial class UIM010210 : FrmBase
  14. {
  15. private string opTime = "";
  16. private string shift = "";
  17. private string group = "";
  18. private string stockNo = "";
  19. int queryType = 0;
  20. public UIM010210()
  21. {
  22. InitializeComponent();
  23. }
  24. private void UIM010210_Load(object sender, EventArgs e)
  25. {
  26. //默认查询入库记录
  27. this.ddlQueryType.Value = 0;
  28. this.QueryCustomers();//查询并显示收货单位
  29. this.ExportColumnsInit();//初始化导出字段设定
  30. }
  31. /// <summary>
  32. /// 导出时不需要显示的字段
  33. /// </summary>
  34. string[] ExportColumns;
  35. /// <summary>
  36. /// 不需要导出的字段的名字组初始化
  37. /// </summary>
  38. private void ExportColumnsInit()
  39. {
  40. this.ExportColumns = new string[]{
  41. "YARD_ENTRY_DTIME",
  42. "TRNF_DTIME",
  43. "PRODNM_CD",
  44. "CZSJ",
  45. "SHIFT",
  46. "WKGROUP",
  47. "CZR",
  48. "ZPH",
  49. "TOT_DEC_GRD",
  50. "INGR_DEC_GRD",
  51. "MATLQLTY_DEC_GRD",
  52. "SIZE_DEC_RST",
  53. "EXTSHAPE_DEC_GRD",
  54. "WGT_DEC_RST",
  55. "ORD_NO",
  56. "ORD_SEQ",
  57. "DLIV_TP",
  58. "ORDCUST_CD",
  59. "CHARGE_NO",
  60. "OP_TYPE",
  61. "DLIV_DIRNO",
  62. "ORD_DEVLMT_DATE",
  63. "SMP_NO",
  64. "LC_YSREL",
  65. "LC_YSRP",
  66. "LC_EL50",
  67. "LC_EL80"
  68. };
  69. }
  70. public override void ToolBar_Click(object sender, string ToolbarKey)
  71. {
  72. switch (ToolbarKey)
  73. {
  74. case "Query":
  75. this.label1.Focus();
  76. this.DoQuery();
  77. break;
  78. case "Save":
  79. this.DoSave();
  80. break;
  81. case "Exit":
  82. this.Close();
  83. break;
  84. case "":
  85. break;
  86. }
  87. }
  88. /// <summary>
  89. /// 查询原料库钢卷出入库记录
  90. /// </summary>
  91. private void DoQuery()
  92. {
  93. try
  94. {
  95. this.dataSet1.Tables[0].Clear();
  96. string startTime =this.dteStartDate.DateTime.ToString("yyyyMMdd");//开始时间 1
  97. opTime = this.dteStartDate.DateTime.ToString("yyyy年MM月dd日");
  98. string endTime =this.dteEndDate.DateTime.ToString("yyyyMMdd");//结束时间 2
  99. string specStlGrd = this.txtSPEC_STL_GRD.Text;//牌号 3
  100. string coilWthMin = this.txtWidth_1.Text;//宽度最小值 4
  101. string coilWthMax = this.txtWidth_2.Text;//宽度最大值 5
  102. string coilThkMin = this.txtThick_1.Text;//厚度最小值 6
  103. string coilThkMax = this.txtThick_2.Text;//厚度最大值 7
  104. string curLoadLoc = this.txtCUR_LOAD_LOC.Text;//垛位 8
  105. string coilNo = this.txtOLD_SAMPL_NO.Text;//钢卷号 9
  106. shift = (-1 >= this.ddlShift.SelectedIndex ) ? "" : this.ddlShift.Value.ToString();//班次 10
  107. group = (-1 >= this.ddlWKGroup.SelectedIndex ) ? "" : this.ddlWKGroup.Value.ToString();//班组 11
  108. string regId = this.txtCZR.Text;//作业人12
  109. string custCd = (-1 == this.ddlDLIV_tp.SelectedIndex) ? "" : this.ddlDLIV_tp.Value.ToString();//客户编号13
  110. string ordNo = this.txtORD_NO.Text;//订单号14
  111. string ordSeq = this.txtORD_SQE.Text;//合同号15
  112. string ordFl = (-1 >= this.ddlSEQType.SelectedIndex || this.ddlSEQType.Value == null) ? "" : this.ddlSEQType.Value.ToString();//订单区分16
  113. //string prodnmCd = -1 == this.ddlProductType.SelectedIndex ? "" : this.ddlProductType.Value.ToString();//产品类型17
  114. stockNo = 0 > this.ultraComboEditor1.SelectedIndex ? "" : this.ultraComboEditor1.Value.ToString();
  115. //string deldatefr = this.ultraDateTimeEditor4.DateTime.ToString("yyyyMMdd");//交货期开始时间
  116. //string deldateto = this.ultraDateTimeEditor3.DateTime.ToString("yyyyMMdd");//结束时间
  117. string deldatefr = this.ultraDateTimeEditor4.Value != null ? ultraDateTimeEditor4.DateTime.ToString("yyyyMMdd") : "";//入库开始时间
  118. string deldateto = this.ultraDateTimeEditor3.Value != null ? ultraDateTimeEditor3.DateTime.ToString("yyyyMMdd") : "";//入库结束时间
  119. queryType = int.Parse(this.ddlQueryType.Value.ToString());//查询类型 0 入库记录 1 出库记录
  120. string[] queryParams = new string[] { startTime, endTime, specStlGrd, coilWthMin, coilWthMax,
  121. coilThkMin, coilThkMax, curLoadLoc, coilNo, shift, group, regId, custCd, ordNo, ordSeq,
  122. ordFl, "",stockNo,deldatefr,deldateto};
  123. for(int i = 0;i < queryParams.Length;i++)
  124. {
  125. if (queryParams[i] == null)
  126. {
  127. queryParams[i] = "";
  128. }
  129. }
  130. List<string[]> list = new List<String[]>();
  131. list.Add(queryParams);
  132. CoreClientParam ccp = new CoreClientParam();
  133. ccp.ServerName = "UIM.UIM010210";
  134. ccp.MethodName = "queryYardList";
  135. ccp.ServerParams = new object[] { queryType, list };
  136. ccp.SourceDataTable = this.dataSet1.Tables[0];
  137. this.ExecuteQueryToDataTable(ccp, CoreInvokeType.Internal);
  138. DataRowCollection drs = this.dataSet1.Tables[0].Rows;
  139. int coilCount = 0;
  140. double wgtCount = 0;
  141. int drsSize = drs.Count;
  142. coilCount = drsSize;
  143. for (int i = 0; i < drsSize; i++)
  144. {
  145. double actWgt = 0;
  146. try
  147. {
  148. actWgt = double.Parse(drs[i]["ACT_WGT"].ToString());
  149. }
  150. catch (Exception e)
  151. {
  152. }
  153. wgtCount += actWgt;
  154. }
  155. if (coilCount == 0)
  156. {
  157. this.textBox1.Text = "";
  158. this.textBox2.Text = "";
  159. }
  160. else
  161. {
  162. this.textBox1.Text = coilCount.ToString();
  163. this.textBox2.Text = (wgtCount / 1000).ToString();
  164. }
  165. }
  166. catch (Exception EX)
  167. {
  168. MessageBox.Show(EX.ToString());
  169. }
  170. }
  171. /// <summary>
  172. /// 查询并显示收货单位
  173. /// </summary>
  174. private void QueryCustomers()
  175. {
  176. CoreClientParam ccp = new CoreClientParam();
  177. ccp.ServerName = "UIM.UIM010060";
  178. ccp.MethodName = "queryCustomers";
  179. ccp = this.ExecuteQuery(ccp, CoreInvokeType.Internal);
  180. ArrayList custList = (ArrayList)ccp.ReturnObject;
  181. int listSize = custList.Count;
  182. Infragistics.Win.ValueListItem[] valueListItems = new Infragistics.Win.ValueListItem[listSize];
  183. for (int i = 0; i < listSize; i++)
  184. {
  185. Infragistics.Win.ValueListItem item = new Infragistics.Win.ValueListItem();
  186. Hashtable ht = (Hashtable)custList[i];
  187. item.DataValue = ht["VALUE"].ToString();
  188. object obj = ht["LABEL"];
  189. if (obj != null)
  190. {
  191. item.DisplayText = ht["LABEL"].ToString();
  192. }
  193. else
  194. {
  195. item.DisplayText = "";
  196. }
  197. valueListItems[i] = item;
  198. }
  199. this.ddlDLIV_tp.Items.AddRange(valueListItems);
  200. }
  201. /// <summary>
  202. /// 导出
  203. /// </summary>
  204. private void DoSave()
  205. {
  206. try
  207. {
  208. if (this.saveFileDialog1.ShowDialog() != DialogResult.OK)
  209. {
  210. return;
  211. }
  212. this.dataSet1.Tables[0].Columns["ACT_WGT"].Caption = "卷重(吨)";
  213. foreach (string columnStr in ExportColumns)
  214. {
  215. this.ultraGrid1.DisplayLayout.Bands[0].Columns[columnStr].Hidden = true;
  216. }
  217. if(this.ddlQueryType.SelectedIndex == 1)
  218. {
  219. this.ultraGrid1.DisplayLayout.Bands[0].Columns["CUR_LOAD_LOC"].Hidden = true;
  220. }
  221. // 如果加单位会导致统计数据出错
  222. for (int i = 0; i < this.ultraGrid1.Rows.Count; i++)
  223. {
  224. Infragistics.Win.UltraWinGrid.UltraGridRow row = this.ultraGrid1.Rows[i];
  225. double tempWGT;
  226. double.TryParse(row.Cells["ACT_WGT"].Value.ToString(), out tempWGT);
  227. tempWGT = tempWGT * 0.001;
  228. row.Cells["ACT_WGT"].Value = (tempWGT.ToString());
  229. }
  230. string title = "成品库";
  231. if (stockNo == "3")
  232. {
  233. title = "连退库";
  234. }
  235. else if(stockNo == "4")
  236. {
  237. title = "连退库";
  238. }
  239. else if (stockNo == "5")
  240. {
  241. title = "重卷库";
  242. }
  243. if (queryType == 0)
  244. {
  245. title += "入库单";
  246. }
  247. else
  248. {
  249. title += "出库单";
  250. }
  251. string operation = "";
  252. if (opTime != "")
  253. {
  254. operation += opTime + " ";
  255. }
  256. operation += tools.UserInfoExt.Get_UserOrder(UserInfo) + "/" + tools.UserInfoExt.Get_UserGroup(UserInfo);
  257. this.ultraGrid1.DisplayLayout.AutoFitStyle = Infragistics.Win.UltraWinGrid.AutoFitStyle.None;
  258. string filepath = this.saveFileDialog1.FileName;
  259. ultraGridExcelExporter1.Export(ultraGrid1, filepath);
  260. Microsoft.Office.Interop.Excel.Application excel;
  261. Microsoft.Office.Interop.Excel._Workbook objBook;
  262. Microsoft.Office.Interop.Excel.Workbooks objBooks;//接口 workbooks
  263. Microsoft.Office.Interop.Excel.Sheets objSheets;// 接口 sheets
  264. Microsoft.Office.Interop.Excel.Worksheet objSheet;//接口 worksheet
  265. Microsoft.Office.Interop.Excel.Range range = null;
  266. try
  267. {
  268. excel = new Microsoft.Office.Interop.Excel.Application();
  269. objBooks = excel.Workbooks;
  270. //Object miss = System.Reflection.Missing.Value;
  271. objBook = objBooks.Add(filepath);
  272. objSheets = objBook.Sheets;
  273. objSheet = (Microsoft.Office.Interop.Excel.Worksheet)objSheets[1];
  274. excel.Visible = false; //让后台执行设置为不可见,为true的话会看到打开一个Excel,然后数据在往里写
  275. Microsoft.Office.Interop.Excel.Range tmpRange = (Microsoft.Office.Interop.Excel.Range)objSheet.Rows[1, System.Reflection.Missing.Value];
  276. tmpRange.Insert(Microsoft.Office.Interop.Excel.XlInsertShiftDirection.xlShiftDown, System.Reflection.Missing.Value);
  277. tmpRange.Insert(Microsoft.Office.Interop.Excel.XlInsertShiftDirection.xlShiftDown, System.Reflection.Missing.Value);
  278. objSheet.get_Range("A1", queryType == 0 ? "G1" : "F1").Merge(objSheet.get_Range("A1", queryType == 0 ? "G1" : "F1").MergeCells);
  279. objSheet.get_Range("A2", queryType == 0 ? "G2" : "F2").Merge(objSheet.get_Range("A2", queryType == 0 ? "G2" : "F2").MergeCells);
  280. objSheet.get_Range("A1", queryType == 0 ? "G1" : "F1").VerticalAlignment = Microsoft.Office.Interop.Excel.XlVAlign.xlVAlignCenter;
  281. objSheet.get_Range("A2", queryType == 0 ? "G2" : "F2").VerticalAlignment = Microsoft.Office.Interop.Excel.XlVAlign.xlVAlignCenter;
  282. objSheet.get_Range("A1", queryType == 0 ? "G1" : "F1").HorizontalAlignment = Microsoft.Office.Interop.Excel.XlHAlign.xlHAlignCenter;
  283. objSheet.get_Range("A2", queryType == 0 ? "G2" : "F2").HorizontalAlignment = Microsoft.Office.Interop.Excel.XlHAlign.xlHAlignLeft;
  284. ((Microsoft.Office.Interop.Excel.Range)objSheet.UsedRange.Cells[1, 1]).Font.Size = 24;
  285. ((Microsoft.Office.Interop.Excel.Range)objSheet.UsedRange.Cells[1, 1]).RowHeight = 45;
  286. ((Microsoft.Office.Interop.Excel.Range)objSheet.UsedRange.Cells[1, 1]).Font.Bold = true;
  287. ((Microsoft.Office.Interop.Excel.Range)objSheet.UsedRange.Cells[1, 1]).Interior.Color = ((Microsoft.Office.Interop.Excel.Range)objSheet.UsedRange.Cells[4, 1]).Interior.Color;
  288. ((Microsoft.Office.Interop.Excel.Range)objSheet.UsedRange.Cells[2, 1]).Interior.Color = ((Microsoft.Office.Interop.Excel.Range)objSheet.UsedRange.Cells[4, 1]).Interior.Color;
  289. excel.Cells[1, 1] = title;
  290. excel.Cells[2, 1] = operation;
  291. int iRowCnt = objSheet.UsedRange.Cells.Rows.Count;
  292. int iBgnRow = (objSheet.UsedRange.Cells.Row > 3 ? objSheet.UsedRange.Cells.Row : objSheet.UsedRange.Cells.Row + 1) + 1;
  293. int insertIdx = iRowCnt - 1, insertIdx1 = iRowCnt - 1;
  294. string befStlStr = ((Microsoft.Office.Interop.Excel.Range)objSheet.UsedRange.Cells[insertIdx - 1, queryType == 0 ? 2 : 2]).Text.ToString();
  295. string befThkStr = GetThickBySize(((Microsoft.Office.Interop.Excel.Range)objSheet.UsedRange.Cells[insertIdx - 1, queryType == 0 ? 3 : 3]).Text.ToString());
  296. string curStlStr = string.Empty, curThkStr = string.Empty;
  297. int coilCount = 0, coilCount1 = 0;
  298. double weightSum = 0, weightSum1 = 0;
  299. for (int i = iRowCnt - 2; i >= iBgnRow; i--)
  300. {
  301. curStlStr = ((Microsoft.Office.Interop.Excel.Range)objSheet.UsedRange.Cells[i, queryType == 0 ? 2 : 2]).Text.ToString();
  302. curThkStr = GetThickBySize(((Microsoft.Office.Interop.Excel.Range)objSheet.UsedRange.Cells[i, queryType == 0 ? 3 : 3]).Text.ToString());
  303. if (!befStlStr.Equals(curStlStr) || !befThkStr.Equals(curThkStr))
  304. {
  305. if (!befStlStr.Equals(curStlStr))
  306. {
  307. tmpRange = (Microsoft.Office.Interop.Excel.Range)objSheet.Rows[insertIdx1, System.Reflection.Missing.Value];
  308. tmpRange.Insert(Microsoft.Office.Interop.Excel.XlInsertShiftDirection.xlShiftDown, System.Reflection.Missing.Value);
  309. excel.Cells[insertIdx1, queryType == 0 ? 1 : 1] = coilCount1.ToString();
  310. excel.Cells[insertIdx1, queryType == 0 ? 5 : 5] = weightSum1.ToString();
  311. coilCount1 = 0;
  312. weightSum1 = 0;
  313. insertIdx1 = i;
  314. }
  315. tmpRange = (Microsoft.Office.Interop.Excel.Range)objSheet.Rows[insertIdx, System.Reflection.Missing.Value];
  316. tmpRange.Insert(Microsoft.Office.Interop.Excel.XlInsertShiftDirection.xlShiftDown, System.Reflection.Missing.Value);
  317. excel.Cells[insertIdx, queryType == 0 ? 1 : 1] = coilCount.ToString();
  318. excel.Cells[insertIdx, queryType == 0 ? 5 : 5] = weightSum.ToString();
  319. coilCount = 0;
  320. weightSum = 0;
  321. insertIdx = i + 1;
  322. insertIdx1++;
  323. }
  324. if (i > iBgnRow)
  325. {
  326. coilCount++;
  327. weightSum += Convert.ToDouble(((Microsoft.Office.Interop.Excel.Range)objSheet.UsedRange.Cells[i, queryType == 0 ? 5 : 5]).Text);
  328. coilCount1++;
  329. weightSum1 += Convert.ToDouble(((Microsoft.Office.Interop.Excel.Range)objSheet.UsedRange.Cells[i, queryType == 0 ? 5 : 5]).Text);
  330. }
  331. befStlStr = curStlStr;
  332. befThkStr = curThkStr;
  333. }
  334. objBook.SaveCopyAs(filepath);
  335. //设置禁止弹出保存和覆盖的询问提示框
  336. excel.DisplayAlerts = false;
  337. excel.AlertBeforeOverwriting = false;
  338. //确保Excel进程关闭
  339. objBooks.Close();
  340. excel.Workbooks.Close();
  341. excel.Quit();
  342. System.Runtime.InteropServices.Marshal.ReleaseComObject(objBook);
  343. System.Runtime.InteropServices.Marshal.ReleaseComObject(objBooks);
  344. System.Runtime.InteropServices.Marshal.ReleaseComObject(excel);
  345. GC.Collect();
  346. System.GC.WaitForPendingFinalizers();
  347. //MessageBox.Show("数据导出完成!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
  348. if (System.IO.File.Exists(filepath))
  349. System.Diagnostics.Process.Start(filepath); //保存成功后打开此文件
  350. }
  351. catch (Exception ex)
  352. {
  353. MessageBox.Show(ex.Message, "错误提示");
  354. }
  355. }
  356. catch (Exception ex)
  357. {
  358. MessageBox.Show(ex.ToString());
  359. }
  360. }
  361. private void ultraGridExcelExporter1_EndExport(object sender, Infragistics.Win.UltraWinGrid.ExcelExport.EndExportEventArgs e)
  362. {
  363. this.ultraGrid1.BeginUpdate();
  364. this.dataSet1.Tables[0].Columns["ACT_WGT"].Caption = "卷重";
  365. //保险
  366. try
  367. {
  368. for (int i = 0; i < this.ultraGrid1.Rows.Count; i++)
  369. {
  370. Infragistics.Win.UltraWinGrid.UltraGridRow row = this.ultraGrid1.Rows[i];
  371. double tempWGT;
  372. double.TryParse(row.Cells["ACT_WGT"].Value.ToString(), out tempWGT);
  373. tempWGT = tempWGT * 1000;
  374. row.Cells["ACT_WGT"].Value = tempWGT.ToString();
  375. }
  376. }
  377. catch
  378. {
  379. this.DoQuery();
  380. }
  381. foreach (string columnStr in ExportColumns)
  382. {
  383. this.ultraGrid1.DisplayLayout.Bands[0].Columns[columnStr].Hidden = false;
  384. }
  385. this.ultraGrid1.DisplayLayout.Bands[0].Columns["CUR_LOAD_LOC"].Hidden = false;
  386. this.ultraGrid1.DisplayLayout.AutoFitStyle = Infragistics.Win.UltraWinGrid.AutoFitStyle.ExtendLastColumn;
  387. this.ultraGrid1.EndUpdate();
  388. }
  389. private string GetThickBySize(string coilSize)
  390. {
  391. string thick = string.Empty;
  392. if (!string.IsNullOrEmpty(coilSize) && coilSize.Contains("*"))
  393. {
  394. thick = coilSize.Substring(0, coilSize.IndexOf("*"));
  395. }
  396. return thick;
  397. }
  398. private void txtThick_1_TextChanged(object sender, EventArgs e)
  399. {
  400. }
  401. private void button1_Click(object sender, EventArgs e)
  402. {
  403. try
  404. {
  405. if (this.saveFileDialog1.ShowDialog(this) == DialogResult.OK)
  406. {
  407. string fileName = this.saveFileDialog1.FileName;
  408. this.ultraGridExcelExporter1.Export(ultraGrid1, fileName);
  409. System.Diagnostics.Process.Start(fileName);
  410. }
  411. }
  412. catch (Exception ex)
  413. {
  414. MessageBox.Show(ex.ToString());
  415. }
  416. }
  417. }
  418. }