博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
C# Json处理日期和Table
阅读量:7249 次
发布时间:2019-06-29

本文共 6082 字,大约阅读时间需要 20 分钟。

using System;using System.Collections.Generic;using System.Linq;using System.Web;   using System.Runtime.Serialization.Json;   using System.IO;   using System.Text;   using System.Text.RegularExpressions;   ///   /// JSON序列化和反序列化辅助类  ///   public class JsonHelper  {       ///       /// JSON序列化      ///        public static string JsonSerializer
(T t) { DataContractJsonSerializer ser = new DataContractJsonSerializer(typeof(T)); MemoryStream ms = new MemoryStream(); ser.WriteObject(ms, t); string jsonString = Encoding.UTF8.GetString(ms.ToArray()); ms.Close(); //替换Json的Date字符串 string p = @"///Date/((/d+)/+/d+/)///"; /*Date/((([/+/-]/d+)|(/d+))[/+/-]/d+/)*/ MatchEvaluator matchEvaluator = new MatchEvaluator(ConvertJsonDateToDateString); Regex reg = new Regex(p); jsonString = reg.Replace(jsonString, matchEvaluator); return jsonString; } ///
/// JSON反序列化 /// public static T JsonDeserialize
(string jsonString) { //将"yyyy-MM-dd HH:mm:ss"格式的字符串转为"//Date(1294499956278+0800)//"格式 string p = @"/d{4}-/d{2}-/d{2}/s/d{2}:/d{2}:/d{2}"; MatchEvaluator matchEvaluator = new MatchEvaluator(ConvertDateStringToJsonDate); Regex reg = new Regex(p); jsonString = reg.Replace(jsonString, matchEvaluator); DataContractJsonSerializer ser = new DataContractJsonSerializer(typeof(T)); MemoryStream ms = new MemoryStream(Encoding.UTF8.GetBytes(jsonString)); T obj = (T)ser.ReadObject(ms); return obj; } ///
/// 将Json序列化的时间由/Date(1294499956278+0800)转为字符串 /// private static string ConvertJsonDateToDateString(Match m) { string result = string.Empty; DateTime dt = new DateTime(1970,1,1); dt = dt.AddMilliseconds(long.Parse(m.Groups[1].Value)); dt = dt.ToLocalTime(); result = dt.ToString("yyyy-MM-dd HH:mm:ss"); return result; } ///
/// 将时间字符串转为Json时间 /// private static string ConvertDateStringToJsonDate(Match m) { string result = string.Empty; DateTime dt = DateTime.Parse(m.Groups[0].Value); dt = dt.ToUniversalTime(); TimeSpan ts = dt - DateTime.Parse("1970-01-01"); result = string.Format("///Date({0}+0800)///",ts.TotalMilliseconds); return result; } } create table Users( UserId int identity(1,1) primary key, UserName varchar(20))insert into Users values('Bradley')insert into Users values('Dan') public class JsonHelper { #region 序列化和反序列化 // 序列化 public static string JsonSerializer
(T t) { // 使用 DataContractJsonSerializer 将 T 对象序列化为内存流。 DataContractJsonSerializer jsonSerializer = new DataContractJsonSerializer(typeof (T)); MemoryStream ms = new MemoryStream(); // 使用 WriteObject 方法将 JSON 数据写入到流中。 jsonSerializer.WriteObject(ms, t); // 流转字符串 string jsonString = Encoding.UTF8.GetString(ms.ToArray()); ms.Close(); //替换Json的Date字符串 string p = @"\\/Date\((\d+)\+\d+\)\\/"; MatchEvaluator matchEvaluator = new MatchEvaluator(ConvertJsonDateToDateString); Regex reg = new Regex(p); jsonString = reg.Replace(jsonString, matchEvaluator); return jsonString; } public static T JsonDeserialize
(string jsonString) { //将"yyyy-MM-dd HH:mm:ss"格式的字符串转为"\/Date(1294499956278+0800)\/"格式 string p = @"\d{4}-\d{2}-\d{2}\s\d{2}:\d{2}:\d{2}"; MatchEvaluator matchEvaluator = new MatchEvaluator(ConvertDateStringToJsonDate); Regex reg = new Regex(p); jsonString = reg.Replace(jsonString, matchEvaluator); DataContractJsonSerializer jsonSerializer=new DataContractJsonSerializer(typeof(T)); // 字符串转流 MemoryStream ms=new MemoryStream(Encoding.UTF8.GetBytes(jsonString)); // 通过使用 DataContractJsonSerializer 的 ReadObject 方法,将 JSON 编码数据反序列化为T T obj = (T) jsonSerializer.ReadObject(ms); return obj; } public static string ConvertJsonDateToDateString(Match match) { string result = string.Empty; DateTime dateTime=new DateTime(1970,1,1); dateTime = dateTime.AddMilliseconds(long.Parse(match.Groups[1].Value)); dateTime = dateTime.ToLocalTime(); result = dateTime.ToString("yyyy-MM-dd HH:mm:ss"); return result; } private static string ConvertDateStringToJsonDate(Match m) { string result = string.Empty; DateTime dt = DateTime.Parse(m.Groups[0].Value); dt = dt.ToUniversalTime(); TimeSpan ts = dt - DateTime.Parse("1970-01-01"); result = string.Format("\\/Date({0}+0800)\\/",ts.TotalMilliseconds); return result; } #endregion // 对象转换为Json public static string ObjectToJson(object obj) { JavaScriptSerializer js=new JavaScriptSerializer(); try { return js.Serialize(obj); } catch (Exception exception) { throw new Exception(exception.Message); } } // 数据表转化为集合 public static List
> DataTableToList(DataTable dt) { List
> list=new List
>(); foreach (DataRow dataRow in dt.Rows) { Dictionary
dic=new Dictionary
(); foreach (DataColumn dc in dt.Columns) { dic.Add(dc.ColumnName,dataRow[dc.ColumnName]); } list.Add(dic); } return list; } // 表转换为Json public static string DataTableToJson(DataTable dt) { return ObjectToJson(DataTableToList(dt)); } } 来自:http://blog.csdn.net/cncdns/article/details/6164389 http://blog.csdn.net/bradleydan/article/details/7927862

 

你可能感兴趣的文章
linux中父进程退出时如何通知子进程
查看>>
linux 缩减文件系统大小 LVM
查看>>
对比文件md5值实现去重文件
查看>>
C#设计模式之二十三解释器模式(Interpreter Pattern)【行为型】
查看>>
js处理中文乱码记录/nodejs+express error 413
查看>>
基于Keepalived实现LVS双主高可用集群
查看>>
SqlServer 使用脚本创建分发服务及事务复制的可更新订阅
查看>>
什么是Floating (浮动)规则?
查看>>
分布式文件系统-FastDFS
查看>>
HTML5 rotate 做仪表盘
查看>>
为什么说荆州松滋刘氏采穴堂是刘开七、刘广传的后裔
查看>>
React中使用Ant Table组件
查看>>
第四篇 快速、轻量、可扩展、易于使用的EmEditor
查看>>
MySQL删除小写记录
查看>>
用shell脚本收集查询IP信息的网站
查看>>
shiro整合oauth
查看>>
超级网管员——网络管理
查看>>
AjaxControltoolkit(工具包)安装步骤说明
查看>>
利用组策略进行的一次Windows主机安全整改
查看>>
Ruby语法学习笔记(1)
查看>>