一、将DataTable的内容写入到XML文件中

/// <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内

/// <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函数调用

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();

}

DataTable 与XML 交互的更多相关文章

  1. DataTable to byte[]、DataTable to XML(string)

    DataTabe 对象在很多地方都会用到,特别是在Web Service.Socket等需网络传输的地方. 但是在有些地方,如果直接传递的话,程序可能会报告DataTable无法序列化错误. 解决问题 ...

  2. C# datatable 与 xml文件之间的转换

    /// <summary> /// datatable转XML文件 /// </summary> /// <param name="dtTable"& ...

  3. 使用WCF传输DataTable:DataTable和Xml格式的字符串相互转换(C#)

    背景:项目中要用到客户端向服务端传数据,使用WCF,绑定webHttpBinding,做了一个小例子. 业务逻辑简介:客户端在a表中添加了几条数据,从SQL Server数据库直接取出新添加的数据(D ...

  4. 将Xml字符串转换成(DataTable || DataSet || XML)对象

    今天用到一个功能:就是把从数据库读出来的内容转换成XML字符串流格式,并输出给一个功能函数.在写的过程,为方便以后的使用,我对这一功能进行分装.该类的具体格式如下:XmlConvert类命名空间:Ni ...

  5. DataTable ,XML和JSON相互转化

    网上搜集的,保留下来了,有需要的拿去!private string DataTable2Xml(DataTable dt) { StringBuilder xmlBuilder = new Strin ...

  6. Zlib压缩算法在Java与Delphi间交互实现(压缩XML交互)

    一个典型应用中,使用delphi作为客户端,J2EE服务端,两者之间用XML作为数据交换,为了提高效率,对XML数据进行压缩,为此需要找到一种压缩/解压算法能够两个平台之间交互处理,使用ZLIB算法就 ...

  7. 菜鸟必备教程,ajax与xml交互传输数据。

    今天,公司让学习ajax,然而我并不会,着急到爆炸,boom~~啥卡拉咔.看着教程一步一步摸索,写出来交互页面,写代码真的好惆怅啊. 额,不说废话,下面是源代码. 首先是ajax的代码,注释真的很重要 ...

  8. C#中DataTable与XML格式的相互转换

    1.DataTable转换成XML public string ConvertDataTableToXML(DataTable xmlDS) { MemoryStream stream = null; ...

  9. List实体类、DataTable与xml互转

    序列化常用Attribute讲解说明 [XmlRootAttribute("MyCity", Namespace="abc.abc", IsNullable=f ...

随机推荐

  1. OpenCV-Python 绘图功能 | 七

    目标 学习使用OpenCV绘制不同的几何形状 您将学习以下功能:cv.line(),cv.circle(),cv.rectangle(),cv.ellipse(),cv.putText()等. 代码 ...

  2. Github标星过万,Python新手100天学习计划,这次再学不会算我输!

      作为目前最火也是最实用的编程语言,Python不仅是新手入门程序界的首选,也逐渐成为了从大厂到小厂,招牌需求list的必要一条. 当然,学Python这件事情,你可能也和文摘菌一样,已经下了一百次 ...

  3. ios 13 陀螺仪DeviceOrientationEvent需要申请用户权限

    有些代码跑着跑着就报错了,有些陀螺仪用着用着就不能用了. 目前时间是2020.4.4,发现  ios 13系统调用陀螺仪 需要申请用户权限(这应该是个趋势,后面安卓应该陆续跟进).具体实现来看下: 1 ...

  4. iOS UmbrellaFramework

    一.umbrella framework 将几个已经封装好的 framework 封装成一个,封装的这种 framework 就是 umbrella framework. Apple 的官方文档中明确 ...

  5. .Net平台技术栈?不止于此

    首先援引一名工友几年前的文章:http://csharper.blog.51cto.com/3052247/1330022,结合当前微软技术领域及平台工具现状,文章有增改. .NET是个很大.很宽.很 ...

  6. OI滚粗记

    1) 第一次接触OI是在初一,现在算下都四年了,最开始还是用的Pascal,而现在,Pascal都快被淘汰了.四年的OI生涯让我领会了很多,虽然失去了很多,但是也收获了少,这场名叫OI的生活,我不后悔 ...

  7. Mac LaTex中文环境搭建

    为了在博客上写公式,折腾了一晚上Mac上的LaTex的环境搭建,本文对步骤进行记录. 系统:Mac OSX 10.10.5 软件准备 1) MacTex 2015 Distribution (Tex的 ...

  8. linux中的文本处理命令

    一.wc :统计文本的行数.字符数. -l:只显示行数 -d:只显示单词数 -c:只显示字符数 二.tr:转换字符或者删除字符 -d:删除字符 三.cut -d:指定分隔符 -f:指定要显示的字段 例 ...

  9. 探秘 RocketMQ 消息持久化机制

    我们知道 RocketMQ 是一款高性能.高可靠的分布式消息中间件,高性能和高可靠是很难兼得的.因为要保证高可靠,那么数据就必须持久化到磁盘上,将数据持久化到磁盘,那么可能就不能保证高性能了. Roc ...

  10. # H - H HDU - 2066 (多起点、多终点问题)

    H - H HDU - 2066 (多源点.多汇点问题) 一个图上,有M条边,Z个出发点,Y个终止点.求一条最短路,其中起点是Z中的任意一点,终点是Y中任意一点. Input 输入数据有多组,输入直到 ...