C#保存與讀取DataTable信息到XML格式的方法
本文實(shí)例講述了C#保存與讀取DataTable信息到XML格式的方法。分享給大家供大家參考。具體如下:
這里主要實(shí)現(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文件中讀取一個(gè)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();
}
四、程序運(yùn)行結(jié)果
程序運(yùn)行結(jié)果

寫入后的XML文件

希望本文所述對(duì)大家的C#程序設(shè)計(jì)有所幫助。
- C#讀取XML的CDATA節(jié)點(diǎn)內(nèi)容實(shí)例詳解
- C#實(shí)現(xiàn)XML文件讀取
- c#讀取XML多級(jí)子節(jié)點(diǎn)
- C# 創(chuàng)建,讀取,寫入XML文件
- C#讀取XML的三種實(shí)現(xiàn)方式
- 詳解c#讀取XML的實(shí)例代碼
- C#中如何使用 XmlReader 讀取XML文件
- C# winfrom實(shí)現(xiàn)讀取修改xml
- 詳解C#借助.NET框架中的XmlTextReader類讀取XML的方法
- C#讀取xml節(jié)點(diǎn)數(shù)據(jù)方法小結(jié)
- C#從文件流讀取xml文件到DataSet并顯示的方法
- C#讀取Excel并轉(zhuǎn)化成XML的方法
- c# 讀取XML文件的示例
相關(guān)文章
winform下實(shí)現(xiàn)win7 Aero磨砂效果實(shí)現(xiàn)代碼
winform下實(shí)現(xiàn)win7 Aero磨砂效果實(shí)現(xiàn)代碼,需要的朋友可以參考下2012-03-03
C# winform編程中響應(yīng)回車鍵的實(shí)現(xiàn)代碼
這篇文章主要介紹了C# winform編程中響應(yīng)回車鍵的實(shí)現(xiàn)代碼,既在窗口上響應(yīng)回車鍵事件的方法,需要的朋友可以參考下2014-08-08
C#用RabbitMQ實(shí)現(xiàn)消息訂閱與發(fā)布
在消息隊(duì)列模型中,如何將消息廣播到所有的消費(fèi)者,這種模式成為“發(fā)布/訂閱”。本文主要以一個(gè)簡單的小例子,簡述通過fanout交換機(jī),實(shí)現(xiàn)消息的發(fā)布與訂閱,僅供學(xué)習(xí)分享使用,如有不足之處,還請(qǐng)指正。2021-05-05
C#調(diào)用執(zhí)行外部程序的實(shí)現(xiàn)方法
這篇文章主要介紹了C#調(diào)用執(zhí)行外部程序的實(shí)現(xiàn)方法,涉及C#進(jìn)程調(diào)用的相關(guān)使用技巧,非常簡單實(shí)用,需要的朋友可以參考下2015-04-04
C#使用StopWatch獲取程序毫秒級(jí)執(zhí)行時(shí)間的方法
這篇文章主要介紹了C#使用StopWatch獲取程序毫秒級(jí)執(zhí)行時(shí)間的方法,涉及C#操作時(shí)間的相關(guān)技巧,需要的朋友可以參考下2015-04-04

