C#中datatable序列化与反序列化实例分析

本文实例讲述了C#中datatable序列化与反序列化,分享给大家供大家参考。具体方法如下:

一、datatable序列化

public string getSendDetailQuery(DateTime timeS, DateTime timeE, string sccount)
{
  try
  {
 SmsOperate so = new SmsOperate();

    //得到dt
 DataTable dtt = so.getSendDetailQuery(timeS, timeE, sccount);
 JavaScriptSerializer serializer = new JavaScriptSerializer();
 string aaa = Serialize(dtt, false);//datatable不能直接序列化,此为序列化方法
 return "0:" + aaa;

  }
  catch (Exception e)
  {
 return "-1" + e.Message;
  }
}

/// <summary>序列化方法
/// 不需要分页
/// </summary>
/// <param name="dt"></param>
/// <param name="flag">false</param>
/// <returns></returns>
public string Serialize(DataTable dt, bool flag)
{
  JavaScriptSerializer serializer = new JavaScriptSerializer();
  List<Dictionary<string, object>> list = new List<Dictionary<string, object>>();
  foreach (DataRow dr in dt.Rows)
  {
 Dictionary<string, object> result = new Dictionary<string, object>();
 foreach (DataColumn dc in dt.Columns)
 {
   result.Add(dc.ColumnName, dr[dc].ToString());
 }
 list.Add(result);
  }
  return serializer.Serialize(list); ;
}

二、datatable反序列化

public DataTable getSendDetailTest()
{
  DataTable dtb = new DataTable();

  //得到序列化结果aaa
  string aaa = getSendDetailQuery(Convert.ToDateTime("2012-01-01 00:00:00"), Convert.ToDateTime("2012-05-01 23:59:59"), "wangsub1");

  if (aaa.Substring(0, 1) == "0")
  {
 try
 {
   JavaScriptSerializer serializer = new JavaScriptSerializer();
  // var obj = serializer.DeserializeObject(aaa);//反序列化

 aaa=aaa.substring(2,aaa.length-2);

   ArrayList dic = serializer.Deserialize<ArrayList>(aaa);//反序列化ArrayList类型

   if (dic.Count > 0)
   {
 foreach (Dictionary<string, object> drow in dic)
 {
   if (dtb.Columns.Count == 0)
   {
  foreach (string key in drow.Keys)
  {
    dtb.Columns.Add(key, drow[key].GetType());//添加dt的列名
  }
   }
   DataRow row = dtb.NewRow();
   foreach (string key in drow.Keys)
   {

  row[key] = drow[key];//添加列值
   }
   dtb.Rows.Add(row);//添加一行
 }
   }
 }
 catch (Exception e)
 {
   //
 }
  }
  else
  {
 //
  }

  return dtb;
}

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

(0)

相关推荐

  • C#实现json的序列化和反序列化实例代码

    在做asp.net和unity进行http通信的时候,当unity客户端发出表单请求的时候,我要将他要请求的数据以json的格式返回给客户端,让客户端来解析.服务器端这一块就涉及到json的序列化和反序列化的问题. 两种方法都有例子,第一种是用泛型集合来存储的对象,然后将集合序列化一下:第二种是直接序列化的一个对象 复制代码 代码如下: using System;using System.Collections.Generic;using System.Web.Script.Serializat

  • c#数据的序列化和反序列化(推荐版)

    开始用的.net 自带的DataContractJsonSerializer进行序列化和反序列化,当代码写完以后,调试,我X(原谅我的脏话,因为确实让我生气),实体因为有[DataContractAttribute(IsReference=true )] 这样一个属性,提示不能序列化,当然手改一下啦,改完以后,提示基类EntityObject 的这个属性不可以 MY God!! 后来也是因为DataContractJsonSerializer 反序列化成集合的时候不好使,所以才下定决心废弃.采用

  • C#中Serializable序列化实例详解

    本文实例讲述了C#中Serializable序列化.分享给大家供大家参考.具体分析如下: 概述: 序列化就是是将对象转换为容易传输的格式的过程,一般情况下转化打流文件,放入内存或者IO文件 中.例如,可以序列化一个对象,然后使用 HTTP 通过 Internet 在客户端和服务器之间传输该对象,或者和其它应用程序共享使用.反之,反序列化根据流重新构造对象. 一.几种序列化技术  1)二进制序列化保持类型保真度,这对于在应用程序的不同调用之间保留对象的状态很有用.例如,通过将对象序列化到剪贴板,可

  • C#实现复杂XML的序列化与反序列化

    本文以一个实例的形式讲述了C#实现复杂XML的序列化与反序列化的方法.分享给大家供大家参考.具体方法如下: 已知.xml(再此命名default.xml)文件,请将其反序列化到一个实例对象. Default.XML文件如下: <?xml version="1.0" encoding="utf-8" ?> <config> <rules> <rule name="namea"> <params&

  • 深入理解C#序列化与反序列化的详解

    在我们深入探讨C#序列化和反序列化之前我们先要明白什么是序列化,它又称串行化,是.NET运行时环境用来支持用户定义类型的流化的机制.序列化就是把一个对象保存到一个文件或数据库字段中去,反序列化就是在适当的时候把这个文件再转化成原来的对象使用.其目的是以某种存储形成使自定义对象持久化,或者将这种对象从一个地方传输到另一个地方..NET框架提供了两种串行化的方式:1.是使用BinaryFormatter进行串行化:2.使用SoapFormatter进行串行化:3.使用XmlSerializer进行串

  • C#实现对象XML序列化的方法

    本文实例讲述了C#实现对象XML序列化的方法.分享给大家供大家参考.具体实现方法如下: 复制代码 代码如下: using system; using system.xml; using system.xml.serialization; using system.text; using system.io; public class util {     /// <summary>     /// 对象序列化成 xml string     /// </summary>     p

  • C#中JavaScriptSerializer帮助类用法实例

    本文实例讲述了C#中JavaScriptSerializer帮助类用法.分享给大家供大家参考.具体如下: 关键代码如下: 复制代码 代码如下: using System; using System.Collections.Generic; using System.Text.RegularExpressions; using System.Web.Script.Serialization; namespace YanZhiwei.DotNet3._5.Utilities.Common {    

  • C#序列化与反序列化(Serialize,Deserialize)实例详解

    本文实例讲述了C#序列化与反序列化(Serialize,Deserialize)实现方法.分享给大家供大家参考.具体分析如下: 如果要保存运行程序过程的数据要么保存到数据库中,要么新建一个普通的文件,然后把数据保存进去.但是这两者有个缺点就是,不能把原有数据的结构也保存进去.比如一个类中的字段值保存进去后再读取出来必须再解析下才行.序列化技术让你省去了解析的过程.保存后再读取时直接得到一个class 序列化的方式有三种:BinaryFormatter,SoapFormatter,XmlSeria

  • c#对象反序列化与对象序列化示例详解

    1.对象序列化的介绍 (1).NET支持对象序列化的几种方式二进制序列化:对象序列化之后是二进制形式的,通过BinaryFormatter类来实现的,这个类位于System.Runtime.Serialization.Formatters.Binary命名空间下.SOAP序列化:对象序列化之后的结果符合SOAP协议,也就是可以通过SOAP 协议传输,通过System.Runtime.Serialization.Formatters.Soap命名空间下的SoapFormatter类来实现的.XML

  • C# JavaScriptSerializer序列化时的时间处理详解

    最近被序列化困扰了一下下.原因看下面代码 class Program { static void Main(string[] args) { var user = new User { UserId = "sb", CreateDate = DateTime.Now }; var serialier = new JavaScriptSerializer(); var json = serialier.Serialize(user); Console.WriteLine(json); C

随机推荐