XmlToData.cs 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150
  1. using Abp.Logging;
  2. using System.Data;
  3. using System.Xml;
  4. namespace VberZero.Tools.FileHelpers;
  5. /// <summary>
  6. /// XML形式的字符串、XML文江转换成DataSet、DataTable格式
  7. /// </summary>
  8. public static class XmlToData
  9. {
  10. /**//// <summary>
  11. /// 将Xml内容字符串转换成DataSet对象
  12. /// </summary>
  13. /// <param name="xmlStr">Xml内容字符串</param>
  14. /// <returns>DataSet对象</returns>
  15. public static DataSet CXmlToDataSet(this string xmlStr)
  16. {
  17. if (!string.IsNullOrEmpty(xmlStr))
  18. {
  19. StringReader StrStream = null;
  20. XmlTextReader Xmlns = null;
  21. try
  22. {
  23. DataSet ds = new DataSet();
  24. //读取字符串中的信息
  25. StrStream = new StringReader(xmlStr);
  26. //获取StrStream中的数据
  27. Xmlns = new XmlTextReader(StrStream);
  28. //ds获取Xmlns中的数据
  29. ds.ReadXml(Xmlns);
  30. return ds;
  31. }
  32. catch (Exception e)
  33. {
  34. LogHelper.LogException(e);
  35. }
  36. finally
  37. {
  38. //释放资源
  39. if (Xmlns != null)
  40. {
  41. Xmlns.Close();
  42. StrStream.Close();
  43. StrStream.Dispose();
  44. }
  45. }
  46. }
  47. return null;
  48. }
  49. /**//// <summary>
  50. /// 将Xml字符串转换成DataTable对象
  51. /// </summary>
  52. /// <param name="xmlStr">Xml字符串</param>
  53. /// <param name="tableIndex">Table表索引</param>
  54. /// <returns>DataTable对象</returns>
  55. public static DataTable CXmlToDataTable(this string xmlStr, int tableIndex)
  56. {
  57. return CXmlToDataSet(xmlStr).Tables[tableIndex];
  58. }
  59. /**//// <summary>
  60. /// 将Xml字符串转换成DataTable对象
  61. /// </summary>
  62. /// <param name="xmlStr">Xml字符串</param>
  63. /// <returns>DataTable对象</returns>
  64. public static DataTable CXmlToDataTable(this string xmlStr)
  65. {
  66. return CXmlToDataSet(xmlStr).Tables[0];
  67. }
  68. /**//// <summary>
  69. /// 读取Xml文件信息,并转换成DataSet对象
  70. /// </summary>
  71. /// <remarks>
  72. /// DataSet ds = new DataSet();
  73. /// ds = CXmlFileToDataSet("C:/XML/upload.xml");
  74. /// </remarks>
  75. /// <param name="xmlFilePath">Xml文件地址(绝对路径)</param>
  76. /// <returns>DataSet对象</returns>
  77. public static DataSet CXmlFileToDataSet(this string xmlFilePath)
  78. {
  79. if (!string.IsNullOrEmpty(xmlFilePath))
  80. {
  81. //string path = HttpContext.Current.Server.MapPath(xmlFilePath);
  82. string path = xmlFilePath;
  83. StringReader StrStream = null;
  84. XmlTextReader Xmlns = null;
  85. try
  86. {
  87. XmlDocument xmlDoc = new XmlDocument();
  88. //根据地址加载Xml文件
  89. xmlDoc.Load(path);
  90. DataSet ds = new DataSet();
  91. //读取文件中的字符流
  92. StrStream = new StringReader(xmlDoc.InnerXml);
  93. //获取StrStream中的数据
  94. Xmlns = new XmlTextReader(StrStream);
  95. //ds获取Xmlns中的数据
  96. ds.ReadXml(Xmlns);
  97. return ds;
  98. }
  99. catch (Exception e)
  100. {
  101. LogHelper.LogException(e);
  102. }
  103. finally
  104. {
  105. //释放资源
  106. if (Xmlns != null)
  107. {
  108. Xmlns.Close();
  109. StrStream.Close();
  110. StrStream.Dispose();
  111. }
  112. }
  113. }
  114. return null;
  115. }
  116. /**//// <summary>
  117. /// 读取Xml文件信息,并转换成DataTable对象
  118. /// </summary>
  119. /// <param name="xmlFilePath">xml文江路径</param>
  120. /// <param name="tableIndex">Table索引</param>
  121. /// <returns>DataTable对象</returns>
  122. public static DataTable CXmlFileToDataTable(this string xmlFilePath, int tableIndex)
  123. {
  124. return CXmlFileToDataSet(xmlFilePath).Tables[tableIndex];
  125. }
  126. /**//// <summary>
  127. /// 读取Xml文件信息,并转换成DataTable对象
  128. /// </summary>
  129. /// <param name="xmlFilePath">xml文江路径</param>
  130. /// <returns>DataTable对象</returns>
  131. public static DataTable CXmlFileToDataTable(this string xmlFilePath)
  132. {
  133. return CXmlFileToDataSet(xmlFilePath).Tables[0];
  134. }
  135. }