ONHDataHelper.cs 8.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278
  1. using System;
  2. using System.IO;
  3. using System.Linq;
  4. using System.Xml.Linq;
  5. namespace Core.ONH.Collection.comm
  6. {
  7. public class ONHDataHelper
  8. {
  9. private static volatile ONHDataHelper _instance;
  10. private static readonly object LockHelper = new object();
  11. private readonly string _path;
  12. private int hDecimals;
  13. private bool hFlag;
  14. private int nDecimals;
  15. private bool nFlag;
  16. private int oDecimals;
  17. private bool oFlag;
  18. public Action<object, string> ReceiveData = null;
  19. /// <summary>
  20. /// 构造
  21. /// </summary>
  22. private ONHDataHelper()
  23. {
  24. _path = Environment.CurrentDirectory + "\\Decimals.xml";
  25. oFlag = XmlHelper.GetXmlData(_path, "OFlag", true);
  26. nFlag = XmlHelper.GetXmlData(_path, "NFlag", true);
  27. hFlag = XmlHelper.GetXmlData(_path, "HFlag", true);
  28. oDecimals = XmlHelper.GetXmlData(_path, "ODecimals", 4);
  29. nDecimals = XmlHelper.GetXmlData(_path, "NDecimals", 4);
  30. hDecimals = XmlHelper.GetXmlData(_path, "HDecimals", 5);
  31. }
  32. public bool OFlag
  33. {
  34. get { return oFlag; }
  35. set
  36. {
  37. if (oFlag != value)
  38. XmlHelper.SetXmlData(_path, "OFlag", value ? "1" : "0");
  39. oFlag = value;
  40. }
  41. }
  42. public int ODecimals
  43. {
  44. get { return oDecimals; }
  45. set
  46. {
  47. if (oDecimals != value)
  48. XmlHelper.SetXmlData(_path, "ODecimals", value + "");
  49. oDecimals = value;
  50. }
  51. }
  52. public bool NFlag
  53. {
  54. get { return nFlag; }
  55. set
  56. {
  57. if (nFlag != value)
  58. XmlHelper.SetXmlData(_path, "NFlag", value ? "1" : "0");
  59. nFlag = value;
  60. }
  61. }
  62. public int NDecimals
  63. {
  64. get { return nDecimals; }
  65. set
  66. {
  67. if (nDecimals != value)
  68. XmlHelper.SetXmlData(_path, "NDecimals", value + "");
  69. nDecimals = value;
  70. }
  71. }
  72. public bool HFlag
  73. {
  74. get { return hFlag; }
  75. set
  76. {
  77. if (hFlag != value)
  78. XmlHelper.SetXmlData(_path, "HFlag", value ? "1" : "0");
  79. hFlag = value;
  80. }
  81. }
  82. public int HDecimals
  83. {
  84. get { return hDecimals; }
  85. set
  86. {
  87. if (hDecimals != value)
  88. XmlHelper.SetXmlData(_path, "HDecimals", value + "");
  89. hDecimals = value;
  90. }
  91. }
  92. /// <summary>
  93. /// 单列模式
  94. /// </summary>
  95. /// <returns></returns>
  96. public static ONHDataHelper Instance()
  97. {
  98. if (_instance == null)
  99. lock (LockHelper)
  100. {
  101. if (_instance == null)
  102. _instance = new ONHDataHelper();
  103. }
  104. return _instance;
  105. }
  106. public string getONHSql(ONHData onhData)
  107. {
  108. var sql = @"
  109. INSERT INTO PIPEOUTDEC_CHEM_PROCESS_RESULT
  110. (CHECK_NO,
  111. SAMPLE_NO,
  112. VALUE_TYPE,
  113. DEPT_ID,
  114. DEPT_NAME,
  115. DEVICE_NAME,
  116. ANA_O,
  117. ANA_N,
  118. ANA_H)
  119. VALUES
  120. ((SELECT CHECK_NO
  121. FROM PIPE_CHECKCONSIGN_CHEMDETAIL
  122. WHERE SAMPLE_NO = '{0}'
  123. AND ROWNUM = 1),
  124. '{0}',
  125. 2,
  126. '002001007010',
  127. '化学分析室',
  128. '{1}',
  129. {2},
  130. {3},
  131. {4})
  132. ";
  133. return string.Format(sql,
  134. onhData.SampleNo,
  135. onhData.DeviceName,
  136. string.IsNullOrWhiteSpace(onhData.OValue)
  137. ? "NULL"
  138. : (OFlag ? "to_char(ROUND(" + onhData.OValue + "," + ODecimals + "),'"+ (ODecimals==0?"FM999990":"FM999990.".PadRight(9+ODecimals,'0') ) +"')" : onhData.OValue),
  139. string.IsNullOrWhiteSpace(onhData.NValue)
  140. ? "NULL"
  141. : (NFlag ? "to_char(ROUND(" + onhData.NValue + "," + NDecimals + "),'" + (NDecimals == 0 ? "FM999990" : "FM999990.".PadRight(9 + NDecimals, '0')) + "')" : onhData.NValue),
  142. string.IsNullOrWhiteSpace(onhData.HValue)
  143. ? "NULL"
  144. : (HFlag ? "to_char(ROUND(" + onhData.HValue + "," + HDecimals + "),'" + (HDecimals == 0 ? "FM999990" : "FM999990.".PadRight(9 + HDecimals, '0')) + "')" : onhData.HValue)
  145. );
  146. }
  147. /// <summary>
  148. /// 解析ONH原始数据xml文件
  149. /// </summary>
  150. /// <param name="FileName"></param>
  151. /// <param name="data"></param>
  152. public static void AnalysisXml(string FileName, out string data)
  153. {
  154. if (!File.Exists(FileName))
  155. throw new Exception(string.Format("文件:{0} 不存在, 传输失败", FileName));
  156. var rootNode = XElement.Load(FileName);
  157. var xElements = rootNode.Elements("analyse").ToList();
  158. if (xElements.Count <= 0)
  159. throw new Exception("找不到文件试样信息 , 传输失败");
  160. data = "";
  161. var sampleNo = "";
  162. if (TryGetValue(xElements[0], "sample", out sampleNo))
  163. {
  164. // MessageBox.Show(string.Format("试样号:{0}", sampleNo));
  165. }
  166. else
  167. {
  168. throw new Exception("找不到试样号信息 , 传输失败");
  169. }
  170. data = sampleNo;
  171. var xeResults = rootNode.Elements("results").ToList();
  172. var xeResultsDetail = xeResults.SelectMany(p => p.Elements("element")).ToList();
  173. if (xeResultsDetail.Count <= 0)
  174. throw new Exception("找不到试样号检验结果信息 , 传输失败");
  175. foreach (var dataXE in xeResultsDetail)
  176. {
  177. var Name = "";
  178. var Value = "";
  179. if (!TryGetValue(dataXE, "name", out Name))
  180. throw new Exception("数据信息格式错误 , 传输失败");
  181. if (!TryGetValue(dataXE, "value", out Value))
  182. throw new Exception("数据信息格式错误 , 传输失败");
  183. data = data + "," + Name + "," + Value;
  184. }
  185. data = data.ToUpper();
  186. var date = DateTime.Now.ToString("yyyyMMdd");
  187. var time = DateTime.Now.ToString("HHmmss");
  188. var NewPath = Environment.CurrentDirectory + "\\Log\\" + date;
  189. if (!Directory.Exists(NewPath))
  190. Directory.CreateDirectory(NewPath);
  191. NewPath = NewPath + "\\" + sampleNo + "__" + time + ".xml";
  192. File.Copy(FileName, NewPath);
  193. }
  194. public static bool TryGetValue(XElement ex, string elemntName, out string data)
  195. {
  196. data = "";
  197. try
  198. {
  199. var exList = ex.Elements(elemntName).ToList();
  200. if (exList.Count <= 0)
  201. return false;
  202. data = exList[0].FirstNode.ToString();
  203. return true;
  204. }
  205. catch (Exception)
  206. {
  207. return false;
  208. }
  209. }
  210. public static void AnalysisString(string data, out ONHData ONHData)
  211. {
  212. ONHData = new ONHData();
  213. var datas = data.Split(',');
  214. if ((datas.Length < 3) || string.IsNullOrWhiteSpace(datas[0])) return;
  215. ONHData.SampleNo = datas[0];
  216. for (var i = 0; i < (datas.Length - 1)/2; i++)
  217. {
  218. double iData = 0;
  219. var sData = datas[2 + 2*i];
  220. if ((datas[1 + 2*i] == "O") && double.TryParse(sData, out iData))
  221. ONHData.OValue = sData;
  222. if ((datas[1 + 2*i] == "N") && double.TryParse(sData, out iData))
  223. ONHData.NValue = sData;
  224. if ((datas[1 + 2*i] == "H") && double.TryParse(sData, out iData))
  225. ONHData.HValue = sData;
  226. }
  227. ONHData.Valid = true;
  228. }
  229. }
  230. }