版权所有,禁止匿名转载;禁止商业使用。
using System.Xml; using System.Data; namespace Message.Common { /// <summary> /// XML相关通用功能 /// </summary> public class Xml { public Xml() { } /// <summary> /// XML资源类型 /// </summary> public enum XmlType { File, String }; #region 读取XML资源到DataSet中 /// <summary> /// 读取XML资源到DataSet中 /// </summary> /// <param name="source">XML资源,文件为路径,否则为XML字符串</param> /// <param name="xmlType">XML资源类型</param> /// <returns>DataSet</returns> public static DataSet GetDataSet(string source, XmlType xmlType) { DataSet ds = new DataSet(); if (xmlType == XmlType.File) { ds.ReadXml(source); } else { XmlDocument xd = new XmlDocument(); xd.LoadXml(source); XmlNodeReader xnr = new XmlNodeReader(xd); ds.ReadXml(xnr); } return ds; } #endregion #region 获取一个字符串xml文档中的ds ///<remarks> ///赵洪 ///</remarks> /// <summary> /// 获取一个字符串xml文档中的ds /// </summary> /// <param name="xml_string">含有xml信息的字符串</param> public static void get_XmlValue_ds(string xml_string, ref DataSet ds) { System.Xml.XmlDocument xd = new XmlDocument(); xd.LoadXml(xml_string); XmlNodeReader xnr = new XmlNodeReader(xd); ds.ReadXml(xnr); xnr.Close(); int a = ds.Tables.Count; } #endregion #region 读取XML资源到DataTable中 /// <summary> /// 读取XML资源到DataTable中 /// </summary> /// <param name="source">XML资源,文件为路径,否则为XML字符串</param> /// <param name="xmlType">XML资源类型:文件,字符串</param> /// <param name="tableName">表名称</param> /// <returns>DataTable</returns> public static DataTable GetTable(string source, XmlType xmlType, string tableName) { DataSet ds = new DataSet(); if (xmlType == XmlType.File) { ds.ReadXml(source); } else { XmlDocument xd = new XmlDocument(); xd.LoadXml(source); XmlNodeReader xnr = new XmlNodeReader(xd); ds.ReadXml(xnr); } return ds.Tables[tableName]; } #endregion #region 读取XML资源中指定的DataTable的指定行指定列的值 /// <summary> /// 读取XML资源中指定的DataTable的指定行指定列的值 /// </summary> /// <param name="source">XML资源</param> /// <param name="xmlType">XML资源类型:文件,字符串</param> /// <param name="tableName">表名</param> /// <param name="rowIndex">行号</param> /// <param name="colName">列名</param> /// <returns>值,不存在时返回Null</returns> public static object GetTableCell(string source, XmlType xmlType, string tableName, int rowIndex, string colName) { DataSet ds = new DataSet(); if (xmlType == XmlType.File) { ds.ReadXml(source); } else { XmlDocument xd = new XmlDocument(); xd.LoadXml(source); XmlNodeReader xnr = new XmlNodeReader(xd); ds.ReadXml(xnr); } return ds.Tables[tableName].Rows[rowIndex][colName]; } #endregion #region 读取XML资源中指定的DataTable的指定行指定列的值 /// <summary> /// 读取XML资源中指定的DataTable的指定行指定列的值 /// </summary> /// <param name="source">XML资源</param> /// <param name="xmlType">XML资源类型:文件,字符串</param> /// <param name="tableName">表名</param> /// <param name="rowIndex">行号</param> /// <param name="colIndex">列号</param> /// <returns>值,不存在时返回Null</returns> public static object GetTableCell(string source, XmlType xmlType, string tableName, int rowIndex, int colIndex) { DataSet ds = new DataSet(); if (xmlType == XmlType.File) { ds.ReadXml(source); } else { XmlDocument xd = new XmlDocument(); xd.LoadXml(source); XmlNodeReader xnr = new XmlNodeReader(xd); ds.ReadXml(xnr); } return ds.Tables[tableName].Rows[rowIndex][colIndex]; } #endregion #region 获取一个字符串xml文档中的一个table,指定行,指定列的值 /// <summary> /// 获取一个字符串xml文档中的一个table,指定行,指定列的值 /// </summary> /// <param name="xml_string">含有xml信息的字符串</param> /// <param name="tablename">表名</param> /// <param name="row_index">指定行</param> /// <param name="col_name">指定列名</param> /// <returns>相应节点的值</returns> public static string get_XmlValue(string xml_string, string tablename, int row_index, string col_name) { System.Xml.XmlDocument xd = new XmlDocument(); xd.LoadXml(xml_string); XmlElement root = xd.DocumentElement; XmlNode xe = root.CloneNode(false); xe = root.SelectNodes(tablename).Item(row_index); string val = ""; if (null == xe) { return ""; } foreach (XmlNode xn in xe.ChildNodes) { if (xn.LocalName == col_name) { val = xn.InnerText; break; } } return val; } /// <summary> /// 获取一个xml文件中的一个table,指定行,指定列的值 /// </summary> /// <param name="xml_string">含有xml信息的字符串</param> /// <param name="tablename">表名</param> /// <param name="row_index">指定行</param> /// <param name="col_name">指定列名</param> /// <returns>相应节点的值</returns> public static string get_XmlValue(string xml_string, string tablename, int row_index, string col_name, bool isfile) { System.Xml.XmlDocument xd = new XmlDocument(); if (isfile) xd.Load(xml_string); else xd.LoadXml(xml_string); XmlElement root = xd.DocumentElement; XmlNode xe = root.CloneNode(false); xe = root.SelectNodes(tablename).Item(row_index); string val = ""; if (null == xe) { return ""; } foreach (XmlNode xn in xe.ChildNodes) { if (xn.LocalName == col_name) { val = xn.InnerText; break; } } return val; } #endregion #region 获取一个字符串xml文档中的dt ///<remarks> /// ///</remarks> /// <summary> /// 获取一个字符串xml文档中的dt /// </summary> /// <param name="xml_string">含有xml信息的字符串</param> public static void get_XmlValue_dt(string xml_string, ref DataTable dt, string table_name) { DataSet ds = new DataSet(); System.Xml.XmlDocument xd = new XmlDocument(); xd.LoadXml(xml_string); //System.IO.FileStream fs = new System.IO.FileStream("c:\\aa.xml",System.IO.FileMode.Open); //xd.Save(fs); // System.Xml.XmlReader xr=(System.Xml.XmlReader)((object)sr); //ds=new DataSet(); XmlNodeReader xnr = new XmlNodeReader(xd); ds.ReadXml(xnr); xnr.Close(); dt = ds.Tables[table_name]; } #endregion #region 将DataTable写入XML文件中 /// <summary> /// 将DataTable写入XML文件中 /// </summary> /// <param name="dt">含有数据的DataTable</param> /// <param name="filePath">文件路径</param> public static void SaveTableToFile(DataTable dt, string filePath) { DataSet ds = new DataSet("Config"); ds.Tables.Add(dt.Copy()); ds.WriteXml(filePath); } #endregion #region 将DataTable以指定的根结点名称写入文件 /// <summary> /// 将DataTable以指定的根结点名称写入文件 /// </summary> /// <param name="dt">含有数据的DataTable</param> /// <param name="rootName">根结点名称</param> /// <param name="filePath">文件路径</param> public static void SaveTableToFile(DataTable dt, string rootName, string filePath) { DataSet ds = new DataSet(rootName); ds.Tables.Add(dt.Copy()); ds.WriteXml(filePath); } #endregion #region 使用DataSet方式更新XML文件节点 /// <summary> /// 使用DataSet方式更新XML文件节点 /// </summary> /// <param name="filePath">XML文件路径</param> /// <param name="tableName">表名称</param> /// <param name="rowIndex">行号</param> /// <param name="colName">列名</param> /// <param name="content">更新值</param> /// <returns>更新是否成功</returns> public static bool UpdateTableCell(string filePath, string tableName, int rowIndex, string colName, string content) { bool flag = false; DataSet ds = new DataSet(); ds.ReadXml(filePath); DataTable dt = ds.Tables[tableName]; if (dt.Rows[rowIndex][colName] != null) { dt.Rows[rowIndex][colName] = content; ds.WriteXml(filePath); flag = true; } else { flag = false; } return flag; } #endregion #region 使用DataSet方式更新XML文件节点 /// <summary> /// 使用DataSet方式更新XML文件节点 /// </summary> /// <param name="filePath">XML文件路径</param> /// <param name="tableName">表名称</param> /// <param name="rowIndex">行号</param> /// <param name="colIndex">列号</param> /// <param name="content">更新值</param> /// <returns>更新是否成功</returns> public static bool UpdateTableCell(string filePath, string tableName, int rowIndex, int colIndex, string content) { bool flag = false; DataSet ds = new DataSet(); ds.ReadXml(filePath); DataTable dt = ds.Tables[tableName]; if (dt.Rows[rowIndex][colIndex] != null) { dt.Rows[rowIndex][colIndex] = content; ds.WriteXml(filePath); flag = true; } else { flag = false; } return flag; } #endregion #region 读取XML资源中的指定节点内容 /// <summary> /// 读取XML资源中的指定节点内容 /// </summary> /// <param name="source">XML资源</param> /// <param name="xmlType">XML资源类型:文件,字符串</param> /// <param name="nodeName">节点名称</param> /// <returns>节点内容</returns> public static object GetNodeValue(string source, XmlType xmlType, string nodeName) { XmlDocument xd = new XmlDocument(); if (xmlType == XmlType.File) { xd.Load(source); } else { xd.LoadXml(source); } XmlElement xe = xd.DocumentElement; XmlNode xn = xe.SelectSingleNode("//" + nodeName); if (xn != null) { return xn.InnerText; } else { return null; } } /// <summary> /// 读取XML资源中的指定节点内容 /// </summary> /// <param name="source">XML资源</param> /// <param name="nodeName">节点名称</param> /// <returns>节点内容</returns> public static object GetNodeValue(string source, string nodeName) { if (source == null || nodeName == null || source == "" || nodeName == "" || source.Length < nodeName.Length * 2) { return null; } else { int start = source.IndexOf("<" + nodeName + ">") + nodeName.Length + 2; int end = source.IndexOf("</" + nodeName + ">"); if (start == -1 || end == -1) { return null; } else if (start >= end) { return null; } else { return source.Substring(start, end - start); } } } #endregion #region 更新XML文件中的指定节点内容 /// <summary> /// 更新XML文件中的指定节点内容 /// </summary> /// <param name="filePath">文件路径</param> /// <param name="nodeName">节点名称</param> /// <param name="nodeValue">更新内容</param> /// <returns>更新是否成功</returns> public static bool UpdateNode(string filePath, string nodeName, string nodeValue) { bool flag = false; XmlDocument xd = new XmlDocument(); xd.Load(filePath); XmlElement xe = xd.DocumentElement; XmlNode xn = xe.SelectSingleNode("//" + nodeName); if (xn != null) { xn.InnerText = nodeValue; flag = true; } else { flag = false; } return flag; } #endregion #region 操作xml文件中指定节点的数据 /// <summary> /// 获得xml文件中指定节点的节点数据 /// </summary> /// <param name="TableName"></param> /// <returns></returns> public static string GetNodeInfoByNodeName(string path, string nodeName) { string XmlString = ""; XmlDocument xml = new XmlDocument(); xml.Load(path); System.Xml.XmlElement root = xml.DocumentElement; System.Xml.XmlNode node = root.SelectSingleNode("//" + nodeName); if (node != null) { XmlString = node.InnerText; } return XmlString; } #endregion /// <summary> /// 根据xml路径获取DataSet。如果Table名为空:flag=false 返回所有xml的数据;flag=true 将xml中的table名作为数据项返回。否则根据table名获取相应的table信息返回。 /// </summary> /// <param name="XmlPath">xml文件路径</param> /// <param name="TableName">所要获取的Table名,可为空</param> /// <param name="flag">若为true,则只将所有表名作为数据项返回;若为false,则返回所要获取的Table的所有数据</param> /// <returns>返回所获取的DataSet</returns> /// <summary> /// 根据xml路径获取DataSet。如果Table名为空:flag=false 返回所有xml的数据;flag=true 将xml中的table名作为数据项返回。否则根据table名获取相应的table信息返回。 /// </summary> /// <param name="XmlPath">xml文件路径</param> /// <param name="TableName">所要获取的Table名,可为空</param> /// <param name="flag">若为true,则只将所有表名作为数据项返回;若为false,则返回所要获取的Table的所有数据</param> /// <returns>返回所获取的DataSet</returns> public static DataSet GetTableByXml(string XmlPath, string TableName, bool flag) { DataSet ds = new DataSet(); if (TableName == "") { DataSet ds1 = new DataSet(); ds1.ReadXml(XmlPath); if (ds1.Tables.Count > 0) { if (flag) { DataTable dt = new DataTable("typeTable"); dt.Columns.Add("TableName", typeof(string)); ds.Tables.Add(dt); for (int i = 0; i < ds1.Tables.Count; i++) { DataRow dr = dt.NewRow(); dr["TableName"] = ds1.Tables[i].TableName; ds.Tables["typeTable"].Rows.Add(dr); } } else { ds = ds1.Copy(); } } } else { DataSet ds2 = new DataSet(); ds2.ReadXml(XmlPath); if (ds2.Tables[TableName] != null) { ds.Tables.Add(ds2.Tables[TableName].Copy()); } } return ds; } /// <summary> /// escape invalid Unicode in XML /// </summary> /// <param name="str"></param> /// <returns></returns> public static string Replaceinvalid(string str) { System.Text.RegularExpressions.Regex r = new System.Text.RegularExpressions.Regex("[\x00-\x08|\x0b-\x0c|\x0e-\x1f]"); return r.Replace(str, " "); } /// <summary> /// 获得接口错误信息 /// </summary> /// <param name="errCode">错误编码</param> /// <returns></returns> public static string GetInterfaceErrorString(string errCode) { System.Text.StringBuilder sb = new System.Text.StringBuilder(); sb.Append("<?xml version=\"1.0\" encoding=\"GB2312\"?>"); sb.Append("<Root>"); sb.Append("<Result><return_result>" + errCode + "</return_result></Result>"); sb.Append("</Root>"); return sb.ToString(); } } }