C#保存與讀取DataTable信息到XML格式的方法
本文實例講述了C#保存與讀取DataTable信息到XML格式的方法。分享給大家供大家參考。具體如下:
這里主要實現(xiàn):
1.將DataTable中的信息保存到XML中
2.將以上述格式在XML中保存的信息讀取到DataTable內(nèi)
一、將DataTable的內(nèi)容寫入到XML文件中
/// <summary> /// 將DataTable的內(nèi)容寫入到XML文件中 /// </summary> /// <param name="dt">數(shù)據(jù)源</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文檔創(chuàng)建開始 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結(jié)束 //按行各行 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結(jié)束 writer.WriteEndDocument(); writer.Close(); //XML文檔創(chuàng)建結(jié)束 } catch (Exception ex) { Console.WriteLine(ex.Message); return false; } return true; }
二、將以上述格式在XML中保存的信息讀取到DataTable內(nèi)
/// <summary> /// 從XML文件中讀取一個DataTable /// </summary> /// <param name="dt">數(shù)據(jù)源</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); //讀取行數(shù) int CountOfRows = 0; if (!int.TryParse(((XmlElement)root). GetAttribute("CountOfRows").ToString(), out CountOfRows)) { throw new Exception("行數(shù)轉(zhuǎn)換失敗"); } //讀取列數(shù) int CountOfColumns = 0; if (!int.TryParse(((XmlElement)root). GetAttribute("CountOfColumns").ToString(), out CountOfColumns)) { throw new Exception("列數(shù)轉(zhuǎn)換失敗"); } //從第一行中讀取記錄的列名 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函數(shù)調(diào)用
static void Main(string[] args) { //1.將DataTable內(nèi)容寫入到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文件中讀取內(nèi)容到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(); }
四、程序運行結(jié)果
程序運行結(jié)果
寫入后的XML文件
希望本文所述對大家的C#程序設(shè)計有所幫助。
- C#讀取XML的CDATA節(jié)點內(nèi)容實例詳解
- C#實現(xiàn)XML文件讀取
- c#讀取XML多級子節(jié)點
- C# 創(chuàng)建,讀取,寫入XML文件
- C#讀取XML的三種實現(xiàn)方式
- 詳解c#讀取XML的實例代碼
- C#中如何使用 XmlReader 讀取XML文件
- C# winfrom實現(xiàn)讀取修改xml
- 詳解C#借助.NET框架中的XmlTextReader類讀取XML的方法
- C#讀取xml節(jié)點數(shù)據(jù)方法小結(jié)
- C#從文件流讀取xml文件到DataSet并顯示的方法
- C#讀取Excel并轉(zhuǎn)化成XML的方法
- c# 讀取XML文件的示例
相關(guān)文章
探討C#中Dispose方法與Close方法的區(qū)別詳解
本篇文章是對C#中Dispose方法與Close方法的區(qū)別進行了詳細的分析介紹,需要的朋友參考下2013-06-06C#動態(tài)創(chuàng)建Access數(shù)據(jù)庫及密碼的方法
同為微軟的產(chǎn)品,本文將討論的是C#如何創(chuàng)建Access數(shù)據(jù)庫,同時創(chuàng)建數(shù)據(jù)庫密碼與相關(guān)操作,希望對大家有所幫助。2015-09-09C#使用Enum.TryParse()實現(xiàn)枚舉安全轉(zhuǎn)換
這篇文章介紹了C#使用Enum.TryParse()實現(xiàn)枚舉安全轉(zhuǎn)換的方法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-08-08C#先判斷是否存在再創(chuàng)建文件夾或文件與遞歸計算文件夾大小
這篇文章介紹了C#先判斷是否存在再創(chuàng)建文件夾或文件與遞歸計算文件夾大小的方法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-07-07