CenterQuery.cs 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  1. using Newtonsoft.Json;
  2. using Newtonsoft.Json.Linq;
  3. using PTMedicalInsurance.Common;
  4. using PTMedicalInsurance.Helper;
  5. using System;
  6. using System.Collections.Generic;
  7. using System.ComponentModel;
  8. using System.Data;
  9. using System.Drawing;
  10. using System.Linq;
  11. using System.Text;
  12. using System.Threading.Tasks;
  13. using System.Windows.Forms;
  14. using PTMedicalInsurance.Forms.Setters.CenterQuery;
  15. using PTMedicalInsurance.Variables;
  16. using System.IO;
  17. namespace PTMedicalInsurance.Forms
  18. {
  19. public partial class CenterQuery : Form
  20. {
  21. InvokeHelper invoker = new InvokeHelper();
  22. private JArray drgsArray = new JArray();
  23. public CenterQuery()
  24. {
  25. InitializeComponent();
  26. cbxMedType_1.SelectedIndex = 0;
  27. cbxCertType_1.SelectedIndex = 0;
  28. dtBeginDate_1.Value = DateTime.Now.AddDays(-180);
  29. dpST_2.Value = DateTime.Now.AddDays(-2);
  30. dpET_2.Value = DateTime.Now.AddDays(-2);
  31. GridViewSetter grd = new GridViewSetter();
  32. grd.SetHeaderTextOfResult1(dgvResult1);
  33. grd.SetHeaderTextOfSettlResult3(dgvSettlResult_3);
  34. grd.SetHeaderTextOfSettlResultDetail3(dgvSettlDetailResult_3);
  35. }
  36. private void btnQuery_1_Click(object sender, EventArgs e)
  37. {
  38. JObject joTmp = new JObject();
  39. joTmp.Add("psn_no",tbx_PsnNO_1.Text);
  40. joTmp.Add("psn_cert_type", tools.getDestPosStrBySpliter(cbxCertType_1.Text, 1, "."));
  41. joTmp.Add("certno", tbCertNO_1.Text);
  42. joTmp.Add("med_type", tools.getDestPosStrBySpliter(cbxMedType_1.Text,1,"."));
  43. joTmp.Add("begin_date", dtBeginDate_1.Value.ToString("yyyy-MM-dd"));
  44. joTmp.Add("exp_content", "");
  45. JObject joData = new JObject();
  46. joData.Add("data",joTmp);
  47. JObject joRtn = invoker.invokeCenterService(TradeEnum.Authenticate, joData);
  48. string error = "";
  49. if (JsonHelper.parseCenterReturnJson(joRtn, out error) != 0)
  50. {
  51. MessageBox.Show("查询门诊结算信息异常:" + error);
  52. }
  53. else
  54. {
  55. DataTable dt = JsonConvert.DeserializeObject<DataTable>(joRtn["output"]["result"].ToString(), new ReadDataTableConverter());
  56. dgvResult1.DataSource = dt;
  57. }
  58. }
  59. private void btClose_1_Click(object sender, EventArgs e)
  60. {
  61. Close();
  62. }
  63. private void btQuery_2_Click(object sender, EventArgs e)
  64. {
  65. drgsArray = null;
  66. JObject joTmp = new JObject();
  67. joTmp.Add("InterfaceDr", "13");
  68. joTmp.Add("hospID", "47");
  69. joTmp.Add("hospCode", "H10");
  70. joTmp.Add("StartDate", dpST_2.Value.ToString("yyyy-MM-dd"));
  71. joTmp.Add("EndDate", dpET_2.Value.ToString("yyyy-MM-dd"));
  72. JObject joRtn = invoker.invokeInsuService(JsonHelper.setIrisInpar("09010122",joTmp).ToString(), "查询武汉DRGS清单数据");
  73. string error = "";
  74. if (JsonHelper.parseIrisRtnValue(joRtn, out error) != 0)
  75. {
  76. MessageBox.Show("查询武汉DRGS清单数据异常:" + error);
  77. }
  78. else
  79. {
  80. DataTable dt = JsonConvert.DeserializeObject<DataTable>(joRtn["result"]["SettlData"].ToString(), new ReadDataTableConverter());
  81. drgsArray = JArray.FromObject(joRtn["result"]["data"]);
  82. dgvResult_2.DataSource = dt;
  83. }
  84. }
  85. private void btClose_2_Click(object sender, EventArgs e)
  86. {
  87. Close();
  88. }
  89. private void btExport_2_Click(object sender, EventArgs e)
  90. {
  91. //创建CSV文件
  92. string filePath = $@"{Global.curEvt.path}\csv\{dpST_2.Value.ToString("yyyyMMdd")}-{dpET_2.Value.ToString("yyyyMMdd")}.csv";
  93. //
  94. Log log = new Log();
  95. log.CreateFile(filePath);
  96. if ((drgsArray != null) &&(drgsArray.HasValues))
  97. {
  98. using (StreamWriter sw = new StreamWriter(filePath))
  99. {
  100. // 写入数据
  101. foreach (JToken row in drgsArray)
  102. {
  103. Global.writeLog(row.ToString());
  104. String tmp = JsonHelper.Compress(row.ToString());
  105. sw.WriteLine(tmp);
  106. }
  107. }
  108. MessageBox.Show($"已导入文件{filePath}");
  109. }
  110. else
  111. {
  112. MessageBox.Show($"数组为空,请点击查询或检查日志是否获取到4101A的数据!");
  113. }
  114. }
  115. private void btQuery_3_Click(object sender, EventArgs e)
  116. {
  117. var joTmp = new { data = new { psn_no = tbPsnNO_3.Text, setl_id = tbSettlID_3.Text, mdtrt_id = tbMdtrtID_3.Text } };
  118. JObject joRtn = invoker.invokeCenterService(TradeEnum.QuerySettlInfo,JObject.FromObject(joTmp));
  119. string error;
  120. if (JsonHelper.parseCenterRtnValue(joRtn, out error) != 0)
  121. {
  122. MessageBox.Show($"查询失败:{error}");
  123. }
  124. else
  125. {
  126. JArray jaData = new JArray();
  127. jaData.Add(joRtn["output"]["setlinfo"]);
  128. dgvSettlResult_3.DataSource = (DataTable)jaData.ToObject(typeof(DataTable));
  129. dgvSettlDetailResult_3.DataSource = (DataTable)joRtn["output"]["setldetail"].ToObject(typeof(DataTable));
  130. }
  131. }
  132. private void btClose_3_Click(object sender, EventArgs e)
  133. {
  134. Close();
  135. }
  136. }
  137. }