C#保存与读取DataTable信息到XML格式的方法

本文实例讲述了C#保存与读取DataTable信息到XML格式的方法。分享给大家供大家参考。具体如下:

这里主要实现:

1.将DataTable中的信息保存到XML中

2.将以上述格式在XML中保存的信息读取到DataTable内

一、将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();
}

四、程序运行结果

程序运行结果

写入后的XML文件

希望本文所述对大家的C#程序设计有所帮助。

(0)

相关推荐

  • C# DataTable中查询指定字段名称的数据

    1.查询后获取对应的数据集后,传递参数strcodeName,根据数据集中strcodeName的匹配对应字段,获取数据集中对应的目的字段 复制代码 代码如下: private string GetStrName(DataTable dtable, string strcodeName) {             string Name = strcodeName;             DataRow[] dr = dtable.Select("匹配对应字段=" + strcod

  • C#实现将DataTable内容输出到Excel表格的方法

    本文实例讲述了C#实现将DataTable内容输出到Excel表格的方法.分享给大家供大家参考.具体如下: 1.关于本文 本文描述了一个函数(SaveToExcel),该函数可以将DataTable数据内的数据输出到Excel表格中 2.相关说明 1)本文中使用这个函数将一个DataTable中的内容输出到路径名为addr的目录下: 复制代码 代码如下: public void SaveToExcel(string addr, System.Data.DataTable dt) 2)这个函数需要

  • C#实现DataTable映射成Model的方法(附源码)

    本文实例讲述了C#实现DataTable映射成Model的方法.分享给大家供大家参考,具体如下: 这是数据库开发中经常遇到的问题,当然,这可以用现成的ORM框架来解决,但有些时候,如果DataSet/DataTable是第三方接口返回的,ORM就不方便了,还得自己处理. 反射自然必不可少的,另外考虑到DataTable中的ColumnName通常与Model的PropertyName并不严格对应,可以用Attribute来记录这种映射关系. 步骤1:先创建一个DataFieldAttribute

  • C#实现从多列的DataTable里取需要的几列

    本文实例讲述了C#实现从多列的DataTable里取需要的几列的方法.分享给大家供大家参考,具体如下: 方法一: 也是广为人知的一种: YourDataTable.Columns.Remove("列名"); 但是这种情况只适合于去掉很少列的情况. 如果有很多列我却只要一两列呢,那就得用方法二了. 方法二: 复制代码 代码如下: DataTable dat = YourDataTable.DefaultView.ToTable(false, new string[] { "你要

  • C#中DataTable 转实体实例详解

    因为Linq的查询功能很强大,所以从数据库中拿到的数据为了处理方便,我都会转换成实体集合List<T>. 开始用的是硬编码的方式,好理解,但通用性极低,下面是控件台中的代码: using System; using System.Collections.Generic; using System.Data; using System.Linq; using System.Text; using System.Threading.Tasks; namespace Demo1 { class Pr

  • C# DataTable使用方法详解

    在项目中常常常使用到DataTable,假设DataTable使用得当,不仅能使程序简洁有用,并且可以提高性能,达到事半功倍的效果,现对DataTable的使用技巧进行一下总结. 1.添加引用 using System.Data; 2.创建表 //创建一个空表 DataTable dt = new DataTable(); //创建一个名为"Table_New"的空表 DataTable dt = new DataTable("Table_New"); 3.创建列

  • C#从DataTable获取数据的方法

    本文实例讲述了C#从DataTable获取数据的方法.分享给大家供大家参考.具体如下: 通过通用类,返回一个DataTable,要想显示每个单元格,只要做两次循环即可: foreach (DataRow row in dt.Rows) { foreach (DataColumn column in dt.Columns) { Console.WriteLine(row[column]); } } row[column] 中的column是检索出来的表个列名. 如果想把某列的值拼接字符串,那就去掉

  • C#保存与读取DataTable信息到XML格式的方法

    本文实例讲述了C#保存与读取DataTable信息到XML格式的方法.分享给大家供大家参考.具体如下: 这里主要实现: 1.将DataTable中的信息保存到XML中 2.将以上述格式在XML中保存的信息读取到DataTable内 一.将DataTable的内容写入到XML文件中 /// <summary> /// 将DataTable的内容写入到XML文件中 /// </summary> /// <param name="dt">数据源</p

  • Unity读取Excel文件转换XML格式文件

    本文实例为大家分享了Unity读取Excel文件转换XML格式文件的具体代码,供大家参考,具体内容如下 此方法用到excel.dll 下载连接 点击打开链接 using System.Collections.Generic; using UnityEngine; using System.IO; using System.Xml; using Excel; using System.Data; /// <summary> /// 创建XML表 /// </summary> publ

  • C#中DataTable导出为HTML格式的方法

    前言 在C#中DataTable导出数据的时候,我们需要HTML格式的输出数据, 这时候就需要使用将DataTable导出为到HTML格式的方法了,以下代码就可以帮助我们达到目的. 首先,我们要绑定DataTable和 DataGridView. 一.通过DataTable绑定DataGridView 1. 创建DataTable,添加列 DataTable table = new DataTable(); table.Columns.Add("ID", typeof(int)); t

  • Android实现文件的保存与读取功能示例

    本文实例讲述了Android实现文件的保存与读取功能.分享给大家供大家参考,具体如下: 注: 在Activity中有 getFileDir() 和 getCacheDir(); 方法可以获得当前的手机自带的存储空间中的当前包文件的路径 getFileDir() ----- /data/data/cn.xxx.xxx(当前包)/files getCacheDir() ----- /data/data/cn.xxx.xxx(当前包)/cache 1. 编写文件读取与写入功能实现类 FileServi

  • AngularJS读取JSON及XML文件的方法示例

    本文实例讲述了AngularJS读取JSON及XML文件的方法.分享给大家供大家参考,具体如下: <!doctype html> <meta charset="UTF-8"> <html ng-app='routingDemoApp'> <head> <title>AJAX and promise</title> <link href="bootstrap.min.css" rel=&qu

  • .NetCore获取Json和Xml格式的配置信息

    本篇将和大家分享的是:如何获取Json和Xml格式的配置信息,主要介绍的是Configuration扩展方法的使用,因为netcore的web应用在Startup中已经默认嵌入appsettings.json文件的配置信息,故而我把测试点放在在了netcore的控制台应用上:控制台上使用配置文件也是常用的事情,并且官网实例主要讲解的是json格式,对xml格式直接带过了,因此有了本篇的分享,希望能给你好的帮助: 获取Json配置信息 获取Xml配置信息 获取xml节点属性值 配置文件能否不和应用

  • ASP.NET Core配置教程之读取配置信息

    提到"配置"二字,我想绝大部分.NET开发人员脑海中会立马浮现出两个特殊文件的身影,那就是我们再熟悉不过的app.config和web.config,多年以来我们已经习惯了将结构化的配置信息定义在这两个文件之中.到了.NET Core的时候,很多我们习以为常的东西都发生了改变,其中也包括定义配置的方式.总的来说,新的配置系统显得更加轻量级,并且具有更好的扩展性,其最大的特点就是支持多样化的数据源.我们可以采用内存的变量作为配置的数据源,也可以直接配置定义在持久化的文件甚至数据库中. 由

  • 使用JS读取XML文件的方法

    由于项目上需要解析xml,于是各种百度,然后自己总结了下各个主流浏览器解析xml的方法,只能是很浅显的知道他的用法,但是还没有深层次的研究. 不同的浏览器对xml的解析方式不同,根据目前主流浏览器大致分三类: 第一类,ie祖宗: js 提供用于创建 Automation对象的方法,new ActiveXObject("Microsoft.XMLDOM") : 第二类:firefox,opera:用构造函数 DOMParser()实例化DOMParser对象,解析xml文本,并返回xml

  • c# NameValueCollection类读取配置信息

    我首先介绍配置文件中的写法: 1.在VS2005中的工程下建立一个config文件,名称为App.config,并如下编辑: 复制代码 代码如下: <?xml version="1.0" encoding="utf-8" ?> <configuration> <configSections> <section name="StartParameters" type="System.Configu

  • PHP简单读取xml文件的方法示例

    本文实例讲述了PHP简单读取xml文件的方法.分享给大家供大家参考,具体如下: 我将软件版本更新中的版本号等数据信息存放在xml文件中,使用时将版本信息读取出来. xml文件内容如下: <xml version="v1.01" encoding="utf-8"> <updataMessages> <version>v1.8.7</version> </updataMessages> </xml>

随机推荐