爱思开
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

569 lines
23 KiB

2 years ago
  1. using System;
  2. using System.Collections;
  3. using System.Collections.Generic;
  4. using System.Data;
  5. using System.Data.Common;
  6. using System.Linq;
  7. using System.Reflection;
  8. using System.Text;
  9. using System.Threading.Tasks;
  10. namespace ICSSoft.Common
  11. {
  12. public class DataToJsonHelper
  13. {
  14. /* string sql = @"SELECT Identification,y.DepCode,a.ToWarehouseCode AS WarehouseCode
  15. FROM ICSWareHouseLotInfoLog a
  16. INNER JOIN ICSInventoryLotDetail b ON a.LotNo=b.LotNo AND a.WorkPoint=b.WorkPoint
  17. INNER JOIN ICSOApplyNegDetail c ON b.TransCode=c.OApplyNegCode AND b.TransSequence=c.Sequence AND b.WorkPoint=c.WorkPoint
  18. INNER JOIN ICSOOPick x ON c.SourceDetailID=x.PickID AND c.WorkPoint=x.WorkPoint
  19. INNER JOIN ICSOutsourcingOrder y ON x.OODetailID=y.OODetailID AND x.WorkPoint=y.WorkPoint
  20. GROUP BY Identification,y.DepCode,a.ToWarehouseCode
  21. SELECT Identification,y.OOCode,
  22. a.InvCode,SUM(a.Quantity) AS Quantity,0 AS Amount,c.SourceDetailID
  23. FROM ICSWareHouseLotInfoLog a
  24. INNER JOIN ICSInventoryLotDetail b ON a.LotNo=b.LotNo AND a.WorkPoint=b.WorkPoint
  25. INNER JOIN ICSOApplyNegDetail c ON b.TransCode=c.OApplyNegCode AND b.TransSequence=c.Sequence AND b.WorkPoint=c.WorkPoint
  26. INNER JOIN ICSOOPick x ON c.SourceDetailID=x.PickID AND c.WorkPoint=x.WorkPoint
  27. INNER JOIN ICSOutsourcingOrder y ON x.OODetailID=y.OODetailID AND x.WorkPoint=y.WorkPoint
  28. GROUP BY Identification,y.OOCode,a.MUSER,a.InvCode,c.SourceDetailID";
  29. DataSet ds = DBHelper.SQlReturnDataSet(sql, cmd, language);
  30. string RelationName = "details";
  31. DataRelation dr = new DataRelation(RelationName, ds.Tables[0].Columns["Identification"], ds.Tables[1].Columns["Identification"]);
  32. ds.Relations.Add(dr);
  33. string aaa = DataToJson.DataSetToJson(ds, RelationName);
  34. */
  35. /// <summary>
  36. /// DataSet转Json字符串,"主-子-子"结构
  37. /// 需要建立主子表关系,第一张表为主表,第二张表为子表,第三张表为子件表
  38. /// 会排除关联列
  39. /// </summary>
  40. /// <param name="dataSet"></param>
  41. /// <param name="RelationName">关系名称</param>
  42. /// <returns></returns>
  43. public static string DataSetToJson(DataSet dataSet, string RelationName, string column, string RelationName2, string column2)
  44. {
  45. //if (!dataSet.Tables[0].Columns.Contains(column))
  46. //{
  47. //}
  48. DataRelation dataRelation = new DataRelation(RelationName, dataSet.Tables[0].Columns[column], dataSet.Tables[1].Columns[column]);
  49. DataRelation dataRelation2 = new DataRelation(RelationName2, dataSet.Tables[1].Columns[column2], dataSet.Tables[2].Columns[column2], false);
  50. dataSet.Relations.Add(dataRelation);
  51. dataSet.Relations.Add(dataRelation2);
  52. StringBuilder jsonString = new StringBuilder();
  53. //foreach (DataTable table in dataSet.Tables)
  54. //{
  55. DataTable table = dataSet.Tables[0];
  56. DataTable table2 = dataSet.Tables[1];
  57. jsonString.Append("[");
  58. DataRowCollection drc = table.Rows;
  59. for (int i = 0; i < drc.Count; i++)
  60. {
  61. DataRow dataRow = drc[i];
  62. jsonString.Append("{");
  63. for (int j = 0; j < table.Columns.Count; j++)
  64. {
  65. string strKey = table.Columns[j].ColumnName;
  66. if (dataSet.Relations[RelationName].ParentColumns.Select(a => a.Caption).Contains(strKey))
  67. continue;
  68. string strValue = dataRow[j].ToString();
  69. Type type = table.Columns[j].DataType;
  70. jsonString.Append("\"" + strKey + "\":");
  71. strValue = StringFormat(strValue, type);
  72. if (j < table.Columns.Count - 1)
  73. {
  74. jsonString.Append(strValue + ",");
  75. }
  76. else
  77. {
  78. jsonString.Append(strValue);
  79. }
  80. }
  81. jsonString.Append(",\"" + RelationName + "\":");
  82. DataRow[] drs = dataRow.GetChildRows(RelationName);
  83. jsonString.Append("[");
  84. foreach (DataRow dr in drs)
  85. {
  86. DataTable dt = dr.Table;
  87. jsonString.Append("{");
  88. for (int j = 0; j < dt.Columns.Count; j++)
  89. {
  90. string strKey = dt.Columns[j].ColumnName;
  91. if (dataSet.Relations[RelationName].ChildColumns.Select(a => a.Caption).Contains(strKey))
  92. continue;
  93. string strValue = dr[j].ToString();
  94. Type type = dt.Columns[j].DataType;
  95. jsonString.Append("\"" + strKey + "\":");
  96. strValue = StringFormat(strValue, type);
  97. if (j < dt.Columns.Count - 1)
  98. {
  99. jsonString.Append(strValue + ",");
  100. }
  101. else
  102. {
  103. jsonString.Append(strValue);
  104. }
  105. }
  106. ////子件表
  107. jsonString.Append(",\"" + RelationName2 + "\":");
  108. //DataRowCollection drc2 = table2.Rows;
  109. //for (int j = 0; j < drc2.Count; j++)
  110. //{
  111. // DataRow dataRow2 = drc2[j];
  112. DataRow[] drss = dr.GetChildRows(RelationName2);//取不到值
  113. jsonString.Append("[");
  114. foreach (DataRow drSec in drss)
  115. {
  116. DataTable dtSec = drSec.Table;
  117. jsonString.Append("{");
  118. for (int k = 0; k < dtSec.Columns.Count; k++)
  119. {
  120. string strKey = dtSec.Columns[k].ColumnName;
  121. if (dataSet.Relations[RelationName2].ChildColumns.Select(a => a.Caption).Contains(strKey))
  122. continue;
  123. string strValue = drSec[k].ToString();
  124. Type type = dtSec.Columns[k].DataType;
  125. jsonString.Append("\"" + strKey + "\":");
  126. strValue = StringFormat(strValue, type);
  127. if (k < dtSec.Columns.Count - 1)
  128. {
  129. jsonString.Append(strValue + ",");
  130. }
  131. else
  132. {
  133. jsonString.Append(strValue);
  134. }
  135. }
  136. jsonString.Append("},");
  137. }
  138. if (drss.Length > 0)
  139. jsonString.Remove(jsonString.Length - 1, 1);
  140. jsonString.Append("]");//detailss的后方括号
  141. jsonString.Append("},");
  142. }
  143. if (drs.Length > 0)
  144. jsonString.Remove(jsonString.Length - 1, 1);
  145. jsonString.Append("]");
  146. jsonString.Append("},");
  147. }
  148. jsonString.Remove(jsonString.Length - 1, 1);
  149. jsonString.Append("]");
  150. //}
  151. string res = jsonString.ToString();
  152. return res;
  153. }
  154. /// <summary>
  155. /// DataSet转Json字符串,主子结构
  156. /// 需要建立主子表关系,第一张表为主表
  157. /// 会排除关联列
  158. /// </summary>
  159. /// <param name="dataSet"></param>
  160. /// <param name="RelationName">关系名称</param>
  161. /// <returns></returns>
  162. public static string DataSetToJson(DataSet dataSet,string RelationName,string column)
  163. {
  164. //if (!dataSet.Tables[0].Columns.Contains(column))
  165. //{
  166. //}
  167. DataRelation dataRelation = new DataRelation(RelationName, dataSet.Tables[0].Columns[column], dataSet.Tables[1].Columns[column]);
  168. dataSet.Relations.Add(dataRelation);
  169. StringBuilder jsonString = new StringBuilder();
  170. //foreach (DataTable table in dataSet.Tables)
  171. //{
  172. DataTable table = dataSet.Tables[0];
  173. jsonString.Append("[");
  174. DataRowCollection drc = table.Rows;
  175. for (int i = 0; i < drc.Count; i++)
  176. {
  177. DataRow dataRow = drc[i];
  178. jsonString.Append("{");
  179. for (int j = 0; j < table.Columns.Count; j++)
  180. {
  181. string strKey = table.Columns[j].ColumnName;
  182. if (dataSet.Relations[RelationName].ParentColumns.Select(a=>a.Caption).Contains(strKey))
  183. continue;
  184. string strValue = dataRow[j].ToString();
  185. Type type = table.Columns[j].DataType;
  186. jsonString.Append("\"" + strKey + "\":");
  187. strValue = StringFormat(strValue, type);
  188. if (j < table.Columns.Count - 1)
  189. {
  190. jsonString.Append(strValue + ",");
  191. }
  192. else
  193. {
  194. jsonString.Append(strValue);
  195. }
  196. }
  197. jsonString.Append(",\"" + RelationName + "\":");
  198. DataRow[] drs = dataRow.GetChildRows(RelationName);
  199. jsonString.Append("[");
  200. foreach (DataRow dr in drs)
  201. {
  202. DataTable dt = dr.Table;
  203. jsonString.Append("{");
  204. for (int j = 0; j < dt.Columns.Count; j++)
  205. {
  206. string strKey = dt.Columns[j].ColumnName;
  207. if (dataSet.Relations[RelationName].ChildColumns.Select(a => a.Caption).Contains(strKey))
  208. continue;
  209. string strValue = dr[j].ToString();
  210. Type type = dt.Columns[j].DataType;
  211. jsonString.Append("\"" + strKey + "\":");
  212. strValue = StringFormat(strValue, type);
  213. if (j < dt.Columns.Count - 1)
  214. {
  215. jsonString.Append(strValue + ",");
  216. }
  217. else
  218. {
  219. jsonString.Append(strValue);
  220. }
  221. }
  222. jsonString.Append("},");
  223. }
  224. if(drs.Length>0)
  225. jsonString.Remove(jsonString.Length - 1, 1);
  226. jsonString.Append("]");
  227. jsonString.Append("},");
  228. }
  229. jsonString.Remove(jsonString.Length - 1, 1);
  230. jsonString.Append("]");
  231. //}
  232. string res = jsonString.ToString();
  233. return res;
  234. }
  235. #region 私有方法
  236. /// <summary>
  237. /// 过滤特殊字符
  238. /// </summary>
  239. /// <param name="s">字符串</param>
  240. /// <returns>json字符串</returns>
  241. private static string String2Json(String s)
  242. {
  243. StringBuilder sb = new StringBuilder();
  244. for (int i = 0; i < s.Length; i++)
  245. {
  246. char c = s.ToCharArray()[i];
  247. switch (c)
  248. {
  249. case '\"':
  250. sb.Append("\\\""); break;
  251. case '\\':
  252. sb.Append("\\\\"); break;
  253. case '/':
  254. sb.Append("\\/"); break;
  255. case '\b':
  256. sb.Append("\\b"); break;
  257. case '\f':
  258. sb.Append("\\f"); break;
  259. case '\n':
  260. sb.Append("\\n"); break;
  261. case '\r':
  262. sb.Append("\\r"); break;
  263. case '\t':
  264. sb.Append("\\t"); break;
  265. default:
  266. sb.Append(c); break;
  267. }
  268. }
  269. return sb.ToString();
  270. }
  271. /// <summary>
  272. /// 格式化字符型、日期型、布尔型
  273. /// </summary>
  274. /// <param name="str"></param>
  275. /// <param name="type"></param>
  276. /// <returns></returns>
  277. private static string StringFormat(string str, Type type)
  278. {
  279. if (type == typeof(string))
  280. {
  281. str = String2Json(str);
  282. str = "\"" + str + "\"";
  283. }
  284. else if (type == typeof(DateTime))
  285. {
  286. str = "\"" + str + "\"";
  287. }
  288. else if (type == typeof(bool))
  289. {
  290. str = str.ToLower();
  291. }
  292. else if (type != typeof(string) && string.IsNullOrEmpty(str))
  293. {
  294. str = "\"" + str + "\"";
  295. }
  296. return str;
  297. }
  298. #endregion
  299. #region list转换成JSON
  300. /// <summary>
  301. /// list转换为Json
  302. /// </summary>
  303. /// <typeparam name="T"></typeparam>
  304. /// <param name="list"></param>
  305. /// <returns></returns>
  306. public static string ListToJson<T>(IList<T> list)
  307. {
  308. object obj = list[0];
  309. return ListToJson<T>(list, obj.GetType().Name);
  310. }
  311. /// <summary>
  312. /// list转换为json
  313. /// </summary>
  314. /// <typeparam name="T1"></typeparam>
  315. /// <param name="list"></param>
  316. /// <param name="p"></param>
  317. /// <returns></returns>
  318. private static string ListToJson<T>(IList<T> list, string JsonName)
  319. {
  320. StringBuilder Json = new StringBuilder();
  321. if (string.IsNullOrEmpty(JsonName))
  322. JsonName = list[0].GetType().Name;
  323. Json.Append("{\"" + JsonName + "\":[");
  324. if (list.Count > 0)
  325. {
  326. for (int i = 0; i < list.Count; i++)
  327. {
  328. T obj = Activator.CreateInstance<T>();
  329. PropertyInfo[] pi = obj.GetType().GetProperties();
  330. Json.Append("{");
  331. for (int j = 0; j < pi.Length; j++)
  332. {
  333. Type type = pi[j].GetValue(list[i], null).GetType();
  334. Json.Append("\"" + pi[j].Name.ToString() + "\":" + StringFormat(pi[j].GetValue(list[i], null).ToString(), type));
  335. if (j < pi.Length - 1)
  336. {
  337. Json.Append(",");
  338. }
  339. }
  340. Json.Append("}");
  341. if (i < list.Count - 1)
  342. {
  343. Json.Append(",");
  344. }
  345. }
  346. }
  347. Json.Append("]}");
  348. return Json.ToString();
  349. }
  350. #endregion
  351. #region 对象转换为Json
  352. /// <summary>
  353. /// 对象转换为json
  354. /// </summary>
  355. /// <param name="jsonObject">json对象</param>
  356. /// <returns>json字符串</returns>
  357. public static string ToJson(object jsonObject)
  358. {
  359. string jsonString = "{";
  360. PropertyInfo[] propertyInfo = jsonObject.GetType().GetProperties();
  361. for (int i = 0; i < propertyInfo.Length; i++)
  362. {
  363. object objectValue = propertyInfo[i].GetGetMethod().Invoke(jsonObject, null);
  364. string value = string.Empty;
  365. if (objectValue is DateTime || objectValue is Guid || objectValue is TimeSpan)
  366. {
  367. value = "'" + objectValue.ToString() + "'";
  368. }
  369. else if (objectValue is string)
  370. {
  371. value = "'" + ToJson(objectValue.ToString()) + "'";
  372. }
  373. else if (objectValue is IEnumerable)
  374. {
  375. value = ToJson((IEnumerable)objectValue);
  376. }
  377. else
  378. {
  379. value = ToJson(objectValue.ToString());
  380. }
  381. jsonString += "\"" + ToJson(propertyInfo[i].Name) + "\":" + value + ",";
  382. }
  383. jsonString.Remove(jsonString.Length - 1, jsonString.Length);
  384. return jsonString + "}";
  385. }
  386. #endregion
  387. #region 对象集合转换为json
  388. /// <summary>
  389. /// 对象集合转换为json
  390. /// </summary>
  391. /// <param name="array">对象集合</param>
  392. /// <returns>json字符串</returns>
  393. public static string ToJson(IEnumerable array)
  394. {
  395. string jsonString = "{";
  396. foreach (object item in array)
  397. {
  398. jsonString += ToJson(item) + ",";
  399. }
  400. jsonString.Remove(jsonString.Length - 1, jsonString.Length);
  401. return jsonString + "]";
  402. }
  403. #endregion
  404. #region 普通集合转换Json
  405. /// <summary>
  406. /// 普通集合转换Json
  407. /// </summary>
  408. /// <param name="array">集合对象</param>
  409. /// <returns>Json字符串</returns>
  410. public static string ToArrayString(IEnumerable array)
  411. {
  412. string jsonString = "[";
  413. foreach (object item in array)
  414. {
  415. jsonString = ToJson(item.ToString()) + ",";
  416. }
  417. jsonString.Remove(jsonString.Length - 1, jsonString.Length);
  418. return jsonString + "]";
  419. }
  420. #endregion
  421. #region DataSet转换为Json
  422. /// <summary>
  423. /// DataSet转换为Json
  424. /// </summary>
  425. /// <param name="dataSet">DataSet对象</param>
  426. /// <returns>Json字符串</returns>
  427. public static string ToJson(DataSet dataSet)
  428. {
  429. string jsonString = "{";
  430. foreach (DataTable table in dataSet.Tables)
  431. {
  432. jsonString += "\"" + table.TableName + "\":" + ToJson(table) + ",";
  433. }
  434. jsonString = jsonString.TrimEnd(',');
  435. return jsonString + "}";
  436. }
  437. #endregion
  438. #region Datatable转换为Json
  439. /// <summary>
  440. /// Datatable转换为Json
  441. /// </summary>
  442. /// <param name="table">Datatable对象</param>
  443. /// <returns>Json字符串</returns>
  444. public static string ToJson(DataTable dt)
  445. {
  446. StringBuilder jsonString = new StringBuilder();
  447. jsonString.Append("[");
  448. DataRowCollection drc = dt.Rows;
  449. for (int i = 0; i < drc.Count; i++)
  450. {
  451. jsonString.Append("{");
  452. for (int j = 0; j < dt.Columns.Count; j++)
  453. {
  454. string strKey = dt.Columns[j].ColumnName;
  455. string strValue = drc[i][j].ToString();
  456. Type type = dt.Columns[j].DataType;
  457. jsonString.Append("\"" + strKey + "\":");
  458. strValue = StringFormat(strValue, type);
  459. if (j < dt.Columns.Count - 1)
  460. {
  461. jsonString.Append(strValue + ",");
  462. }
  463. else
  464. {
  465. jsonString.Append(strValue);
  466. }
  467. }
  468. jsonString.Append("},");
  469. }
  470. jsonString.Remove(jsonString.Length - 1, 1);
  471. jsonString.Append("]");
  472. return jsonString.ToString();
  473. }
  474. /// <summary>
  475. /// DataTable转换为Json
  476. /// </summary>
  477. public static string ToJson(DataTable dt, string jsonName)
  478. {
  479. StringBuilder Json = new StringBuilder();
  480. if (string.IsNullOrEmpty(jsonName))
  481. jsonName = dt.TableName;
  482. Json.Append("{\"" + jsonName + "\":[");
  483. if (dt.Rows.Count > 0)
  484. {
  485. for (int i = 0; i < dt.Rows.Count; i++)
  486. {
  487. Json.Append("{");
  488. for (int j = 0; j < dt.Columns.Count; j++)
  489. {
  490. Type type = dt.Rows[i][j].GetType();
  491. Json.Append("\"" + dt.Columns[j].ColumnName.ToString() + "\":" + StringFormat(dt.Rows[i][j].ToString(), type));
  492. if (j < dt.Columns.Count - 1)
  493. {
  494. Json.Append(",");
  495. }
  496. }
  497. Json.Append("}");
  498. if (i < dt.Rows.Count - 1)
  499. {
  500. Json.Append(",");
  501. }
  502. }
  503. }
  504. Json.Append("]}");
  505. return Json.ToString();
  506. }
  507. #endregion
  508. #region DataReader转换为Json
  509. /// <summary>
  510. /// DataReader转换为Json
  511. /// </summary>
  512. /// <param name="dataReader">DataReader对象</param>
  513. /// <returns>Json字符串</returns>
  514. public static string ToJson(DbDataReader dataReader)
  515. {
  516. StringBuilder jsonString = new StringBuilder();
  517. jsonString.Append("[");
  518. while (dataReader.Read())
  519. {
  520. jsonString.Append("{");
  521. for (int i = 0; i < dataReader.FieldCount; i++)
  522. {
  523. Type type = dataReader.GetFieldType(i);
  524. string strKey = dataReader.GetName(i);
  525. string strValue = dataReader[i].ToString();
  526. jsonString.Append("\"" + strKey + "\":");
  527. strValue = StringFormat(strValue, type);
  528. if (i < dataReader.FieldCount - 1)
  529. {
  530. jsonString.Append(strValue + ",");
  531. }
  532. else
  533. {
  534. jsonString.Append(strValue);
  535. }
  536. }
  537. jsonString.Append("},");
  538. }
  539. dataReader.Close();
  540. jsonString.Remove(jsonString.Length - 1, 1);
  541. jsonString.Append("]");
  542. return jsonString.ToString();
  543. }
  544. #endregion
  545. }
  546. }