Print.cs 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153
  1. using UAS_MES.DataOperate;
  2. using LabelManager2;
  3. using System.Data;
  4. using System.Text;
  5. using System.IO;
  6. using UAS_MES.Entity;
  7. using System.Windows;
  8. using System.Text.RegularExpressions;
  9. namespace UAS_MES.PublicMethod
  10. {
  11. class Print
  12. {
  13. static DataHelper dh = new DataHelper();
  14. //CodeSoft打印的驱动和文件
  15. static Document doc;
  16. ////CodeSoft的打印机
  17. //string CodeSpft_Printer;
  18. static FileInfo info;
  19. public Print() { }
  20. /// <summary>
  21. /// 默认打印一份
  22. /// </summary>
  23. /// <param name="Url"></param>
  24. /// <param name="LabelCode"></param>
  25. public static void CodeSoft(string iCaller, ApplicationClass lbl, string LabelName, string LabelCode, string PrinterName, string SnCode, int PrintNum, System.DateTime intime)
  26. {
  27. //打开模板路径
  28. doc = lbl.Documents.Open(ftpOperater.DownLoadTo + LabelName);
  29. //查询模板对应的取值SQL和参数名称
  30. DataTable dt = (DataTable)dh.ExecuteSql("select lp_name,lp_sql from label left join LABELPARAMETER on la_id=lp_laid where la_code='" + LabelCode + "'", "select");
  31. //比对模板维护的参数和在系统中维护的参数,名称对应进行SQL取值赋给变量
  32. StringBuilder sb = new StringBuilder();
  33. for (int i = 0; i < doc.Variables.FormVariables.Count; i++)
  34. {
  35. for (int j = 0; j < dt.Rows.Count; j++)
  36. {
  37. if (doc.Variables.FormVariables.Item(i + 1).Name == dt.Rows[j]["lp_name"].ToString())
  38. {
  39. string sql = dt.Rows[j]["lp_sql"].ToString();
  40. try
  41. {
  42. Regex ConnoteA = new Regex("{\\w+}");
  43. foreach (Match mch in ConnoteA.Matches(sql))
  44. {
  45. string x = mch.Value.Trim();
  46. sql = sql.Replace(x,"'" + SnCode + "'");
  47. }
  48. doc.Variables.FormVariables.Item(i + 1).Value = dh.GetLabelParam(sql).ToString();
  49. sb.AppendLine("打印参数【" + doc.Variables.FormVariables.Item(i + 1).Name + "】赋值," + "取值SQL:" + sql + ",取到值" + doc.Variables.FormVariables.Item(i + 1).Value);
  50. }
  51. catch (System.Exception)
  52. {
  53. BaseUtil.ShowError("SQL" + sql + "维护不正确");
  54. }
  55. }
  56. }
  57. }
  58. LogManager.DoLog(sb.ToString());
  59. //保存本次赋值进行打印
  60. doc.Save();
  61. doc.Printer.SwitchTo(PrinterName);
  62. doc.PrintDocument(PrintNum);
  63. doc.Close();
  64. LogicHandler.DoCommandLog(iCaller, User.UserCode, "", User.UserLineCode, User.UserSourceCode, "打印", "成功打印", SnCode, "");
  65. //讲文件最后写入时间改成数据库中拿到的时间
  66. info = new FileInfo(ftpOperater.DownLoadTo + LabelName);
  67. info.LastWriteTime = intime;
  68. }
  69. public static void CodeSoft(string iCaller, Document doc, string LabelName, string LaID, string PrinterName, string SnCode, int PrintNum)
  70. {
  71. //打开模板路径
  72. //查询模板对应的取值SQL和参数名称
  73. DataTable dt = (DataTable)dh.ExecuteSql("select lp_name,lp_sql from label left join LABELPARAMETER on la_id=lp_laid where la_id='" + LaID + "'", "select");
  74. //比对模板维护的参数和在系统中维护的参数,名称对应进行SQL取值赋给变量
  75. StringBuilder sb = new StringBuilder();
  76. for (int i = 0; i < doc.Variables.FormVariables.Count; i++)
  77. {
  78. for (int j = 0; j < dt.Rows.Count; j++)
  79. {
  80. if (doc.Variables.FormVariables.Item(i + 1).Name == dt.Rows[j]["lp_name"].ToString())
  81. {
  82. string sql = dt.Rows[j]["lp_sql"].ToString();
  83. try
  84. {
  85. Regex ConnoteA = new Regex("{\\w+}");
  86. foreach (Match mch in ConnoteA.Matches(sql))
  87. {
  88. string x = mch.Value.Trim();
  89. sql = sql.Replace(x, "'" + SnCode + "'");
  90. }
  91. doc.Variables.FormVariables.Item(i + 1).Value = dh.GetLabelParam(sql).ToString();
  92. sb.AppendLine("打印参数【" + doc.Variables.FormVariables.Item(i + 1).Name + "】赋值," + "取值SQL:" + sql + ",取到值" + doc.Variables.FormVariables.Item(i + 1).Value);
  93. }
  94. catch (System.Exception)
  95. {
  96. BaseUtil.ShowError("SQL" + sql + "维护不正确");
  97. }
  98. }
  99. }
  100. }
  101. LogManager.DoLog(sb.ToString());
  102. //保存本次赋值进行打印
  103. //doc.Save();
  104. doc.Printer.SwitchTo(PrinterName);
  105. doc.PrintDocument(PrintNum);
  106. LogicHandler.DoCommandLog(iCaller, User.UserCode, "", User.UserLineCode, User.UserSourceCode, "打印", "成功打印", SnCode, "");
  107. }
  108. public static void CodeSoft(string iCaller, Document doc, string LabelName, string LabelCode, string PrinterName, string SnCode, int PrintNum, System.DateTime intime)
  109. {
  110. //打开模板路径
  111. //查询模板对应的取值SQL和参数名称
  112. DataTable dt = (DataTable)dh.ExecuteSql("select lp_name,lp_sql from label left join LABELPARAMETER on la_id=lp_laid where la_code='" + LabelCode + "'", "select");
  113. //比对模板维护的参数和在系统中维护的参数,名称对应进行SQL取值赋给变量
  114. StringBuilder sb = new StringBuilder();
  115. for (int i = 0; i < doc.Variables.FormVariables.Count; i++)
  116. {
  117. for (int j = 0; j < dt.Rows.Count; j++)
  118. {
  119. if (doc.Variables.FormVariables.Item(i + 1).Name == dt.Rows[j]["lp_name"].ToString())
  120. {
  121. string sql = dt.Rows[j]["lp_sql"].ToString();
  122. try
  123. {
  124. Regex ConnoteA = new Regex("{\\w+}");
  125. foreach (Match mch in ConnoteA.Matches(sql))
  126. {
  127. string x = mch.Value.Trim();
  128. sql = sql.Replace(x, "'" + SnCode + "'");
  129. }
  130. doc.Variables.FormVariables.Item(i + 1).Value = dh.GetLabelParam(sql).ToString();
  131. sb.AppendLine("打印参数【" + doc.Variables.FormVariables.Item(i + 1).Name + "】赋值," + "取值SQL:" + sql + ",取到值" + doc.Variables.FormVariables.Item(i + 1).Value);
  132. }
  133. catch (System.Exception)
  134. {
  135. BaseUtil.ShowError("SQL" + sql + "维护不正确");
  136. }
  137. }
  138. }
  139. }
  140. LogManager.DoLog(sb.ToString());
  141. //保存本次赋值进行打印
  142. doc.Save();
  143. doc.Printer.SwitchTo(PrinterName);
  144. doc.PrintDocument(PrintNum);
  145. LogicHandler.DoCommandLog(iCaller, User.UserCode, "", User.UserLineCode, User.UserSourceCode, "打印", "成功打印", SnCode, "");
  146. }
  147. }
  148. }