C#保存与读取DataTable信息到XML格式的方法
内容摘要
本文实例讲述了C#保存与读取DataTable信息到XML格式的方法。分享给大家供大家参考。具体如下:
这里主要实现:
1.将DataTable中的信息保存到XML中
2.将以上述格式在XML中保存的
这里主要实现:
1.将DataTable中的信息保存到XML中
2.将以上述格式在XML中保存的
文章正文
本文实例讲述了C#保存与读取DataTable信息到XML格式的方法。分享给大家供大家参考。具体如下:
这里主要实现:
1.将DataTable中的信息保存到XML中
2.将以上述格式在XML中保存的信息读取到DataTable内
一、将DataTable的内容写入到XML文件中
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 | /// <summary> /// 将DataTable的内容写入到XML文件中 /// </summary> /// <param name="dt">数据源</param> /// <param name="address">XML文件地址</param> public static bool WriteToXml(DataTable dt, string address) { try { //如果文件DataTable.xml存在则直接删除 if (File.Exists(address)) { File. Delete (address); } XmlTextWriter writer = new XmlTextWriter(address, Encoding.GetEncoding( "GBK" )); writer.Formatting = Formatting.Indented; //XML文档创建开始 writer.WriteStartDocument(); writer.WriteComment( "DataTable: " + dt.TableName); writer.WriteStartElement( "DataTable" ); //DataTable开始 writer.WriteAttributeString( "TableName" , dt.TableName); writer.WriteAttributeString( "CountOfRows" , dt.Rows. Count .ToString()); writer.WriteAttributeString( "CountOfColumns" , dt.Columns. Count .ToString()); writer.WriteStartElement( "ClomunName" , "" ); //ColumnName开始 for (int i = 0; i < dt.Columns. Count ; i++) { writer.WriteAttributeString( "Column" + i.ToString(), dt.Columns[i].ColumnName); } writer.WriteEndElement(); //ColumnName结束 //按行各行 for (int j = 0; j < dt.Rows. Count ; j++) { writer.WriteStartElement( "Row" + j.ToString(), "" ); //打印各列 for (int k = 0; k < dt.Columns. Count ; k++) { writer.WriteAttributeString( "Column" + k.ToString(), dt.Rows[j][k].ToString()); } writer.WriteEndElement(); } writer.WriteEndElement(); //DataTable结束 writer.WriteEndDocument(); writer.Close(); //XML文档创建结束 } catch (Exception ex) { Console.WriteLine(ex.Message); return false; } return true; } |
二、将以上述格式在XML中保存的信息读取到DataTable内
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 | /// <summary> /// 从XML文件中读取一个DataTable /// </summary> /// <param name="dt">数据源</param> /// <param name="address">XML文件地址</param> /// <returns></returns> public static DataTable ReadFromXml(string address) { DataTable dt = new DataTable(); try { if (!File.Exists(address)) { throw new Exception( "文件不存在!" ); } XmlDocument xmlDoc = new XmlDocument(); xmlDoc.Load(address); XmlNode root = xmlDoc.SelectSingleNode( "DataTable" ); //读取表名 dt.TableName = ((XmlElement)root).GetAttribute( "TableName" ); //Console.WriteLine("读取表名: {0}", dt.TableName); //读取行数 int CountOfRows = 0; if (!int.TryParse(((XmlElement)root). GetAttribute( "CountOfRows" ).ToString(), out CountOfRows)) { throw new Exception( "行数转换失败" ); } //读取列数 int CountOfColumns = 0; if (!int.TryParse(((XmlElement)root). GetAttribute( "CountOfColumns" ).ToString(), out CountOfColumns)) { throw new Exception( "列数转换失败" ); } //从第一行中读取记录的列名 foreach (XmlAttribute xa in root.ChildNodes[0].Attributes) { dt.Columns.Add(xa.Value); //Console.WriteLine("建立列: {0}", xa.Value); } //从后面的行中读取行信息 for (int i = 1; i < root.ChildNodes. Count ; i++) { string[] array = new string[root.ChildNodes[0].Attributes. Count ]; for (int j = 0; j < array .Length; j++) { array [j] = root.ChildNodes[i].Attributes[j].Value.ToString(); } dt.Rows.Add( array ); //Console.WriteLine("行插入成功"); } } catch (Exception ex) { Console.WriteLine(ex.Message); return new DataTable(); } return dt; } |
三、Main函数调用
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 | static void Main(string[] args) { //1.将DataTable内容写入到XML文件 //建立DataTable取名Table4Test DataTable dt1 = new DataTable( "Table4Test" ); //生成四列,列名为Column0-3 dt1.Columns.Add( "Column0" ); dt1.Columns.Add( "Column1" ); dt1.Columns.Add( "Column2" ); dt1.Columns.Add( "Column3" ); //生成四行 dt1.Rows.Add( "A0" , "A1" , "A2" , "A3" ); dt1.Rows.Add( "B0" , "B1" , "B2" , "B3" ); dt1.Rows.Add( "C0" , "C1" , "C2" , "C3" ); //写入到XML if (WriteToXml(dt1, "DataTable.xml" )) { Console.WriteLine( "写入成功" ); } //================================ //2.从XML文件中读取内容到DataTable //读取信息 DataTable dt2 = ReadFromXml( "DataTable.xml" ); //输出读取的信息 Console.WriteLine( "读取到的信息:" ); for (int i = 0; i < dt2.Rows. Count ; i++) { for (int j = 0; j < dt2.Columns. Count ; j++) { Console.Write(dt2.Rows[i][j].ToString() + "\t" ); } Console.WriteLine(); } Console.ReadLine(); } |
四、程序运行结果
程序运行结果
写入后的XML文件
希望本文所述对大家的C#程序设计有所帮助。
代码注释