public class JSON

{

public static string DateTimeFormat = "yyyy'-'MM'-'dd'T'HH':'mm':'ss";

public static string Encode(object o)

{

  if (o == null || o.ToString() == "null") return null;

   if (o != null && (o.GetType() == typeof(String) || o.GetType() == typeof(string)))

{

      return o.ToString();

    }             

IsoDateTimeConverter dt = new IsoDateTimeConverter();

dt.DateTimeFormat = DateTimeFormat;

return JsonConvert.SerializeObject(o, dt);

}

public static object Decode(string json)
        {
            if (String.IsNullOrEmpty(json)) return "";
            object o = JsonConvert.DeserializeObject(json);
            if (o.GetType() == typeof(String) || o.GetType() == typeof(string))
            {
                o = JsonConvert.DeserializeObject(o.ToString());
            }
            object v = toObject(o);
            return v;
        }

public static object Decode(string json, Type type)

{

return JsonConvert.DeserializeObject(json, type);

}

private static object toObject(object o)

{

  if (o == null) return null;

if (o.GetType() == typeof(string))

     {

       //判断是否符合2010-09-02T10:00:00的格式

      string s = o.ToString();

       if (s.Length == 19 && s[10] == 'T' && s[4] == '-' && s[13] == ':')

          {

           o = System.Convert.ToDateTime(o);

                }

        }   else if (o is JObject)

              {

            JObject jo = o as JObject;  

          Hashtable h = new Hashtable();

       foreach (KeyValuePair<string, JToken> entry in jo)

                  {

                 h[entry.Key] = toObject(entry.Value);

                      }  

                o = h;             

          } else if (o is IList)

                    {

          ArrayList list = new ArrayList();

                         list.AddRange((o as IList));

                        int i = 0, l = list.Count;

                        for (; i < l; i++)

               {

                  list[i] = toObject(list[i]);

                          }

                o = list;

          } else if (typeof(JValue) == o.GetType())

                   {

                     JValue v = (JValue)o;

                     o = toObject(v.Value);

                  }else {

                            }

                     return o;

}

public static ArrayList DataTable2ArrayList(DataTable data)

{

ArrayList array = new ArrayList();

for (int i = 0; i < data.Rows.Count; i++)

{

DataRow row = data.Rows[i];

Hashtable record = new Hashtable();

for (int j = 0; j < data.Columns.Count; j++)

{

object cellValue = row[j];

if (cellValue.GetType() == typeof(DBNull))

{

cellValue = null;

}

record[data.Columns[j].ColumnName] = cellValue;

}

array.Add(record);

}

return array;

}

/// <summary>

/// 将一个DataTable 转为一个JSON

/// </summary>

/// <param name="dt"></param>

/// <returns></returns>

public static string DataTable2Json(DataTable dt)

{

if (dt == null)

{

return "";

}

ArrayList dataAll = DataTable2ArrayList(dt);

ArrayList data = new ArrayList();

for (int i = 0, l = dataAll.Count; i < l; i++)

{

Hashtable record = (Hashtable)dataAll[i];

if (record == null) continue;

data.Add("'" + record + "'");

}

Hashtable result = new Hashtable();

result["data"] = data;

result["total"] = dataAll.Count;

return JSON.Encode(dt);

}

/// <summary>

/// 通过一个datatable 返回一个json字符串

/// </summary>

/// <param name="dt">按条件的datatable(分页内的列表)</param>

/// <param name="AllCount">datatable的总条数(分页时的总记录)</param>

/// <returns></returns>

public static string DataTable2Json(DataTable dt, int AllCount)

{

if (dt == null)

{

return "";

}

ArrayList dataAll = DataTable2ArrayList(dt);

//实现一个内存分页(实际应该使用SQL分页)

ArrayList data = new ArrayList();

for (int i = 0, l = dataAll.Count; i < l; i++)

{

Hashtable record = (Hashtable)dataAll[i];

if (record == null) continue;

data.Add(record);

}

Hashtable result = new Hashtable();

result["data"] = data;

result["total"] = AllCount;

return JSON.Encode(result);

}

/// <summary>

/// 通过一个datatable 返回一个json字符串

/// </summary>

/// <param name="dt">按条件的datatable(分页内的列表)</param>

/// <param name="AllCount">datatable的总条数(分页时的总记录)</param>

/// <returns></returns>

public static string DataTable2Json(DataTable dt, int AllCount, Hashtable hashtable)

{

if (dt == null)

{

return "";

}

ArrayList dataAll = DataTable2ArrayList(dt);

//实现一个内存分页(实际应该使用SQL分页)

ArrayList data = new ArrayList();

for (int i = 0, l = dataAll.Count; i < l; i++)

{

Hashtable record = (Hashtable)dataAll[i];

if (record == null) continue;

data.Add(record);

}

Hashtable result = new Hashtable();

result = hashtable;

result["data"] = data;

result["total"] = AllCount;

return JSON.Encode(result);

}

/// <summary>
        /// 分页
        /// </summary>
        /// <param name="data">表dt</param>
        /// <param name="pageIndex">当前页索引</param>
        /// <param name="pageSize">每页的数目</param>
        /// <param name="pageCount">总数目</param>
        /// <returns></returns>
        public static DataTable dt2newdt(DataTable data, int pageIndex, int pageSize, int pageCount)
        {
            DataView dv = data.DefaultView;
            DataTable dt = dv.Table.Clone();
            for (int i = pageIndex * pageSize; i < (pageIndex + 1) * pageSize; i++)
            {
                if (i == pageCount)
                {
                    break;
                }
                dt.ImportRow(dv[i].Row);
            }
            return dt;
        }

}

JSON格式互转集合 (2)的更多相关文章

  1. JSON格式互转集合

    在工作中我们经常会遇到格式转换的问题,有的时候是将JSON转换成DataTable.DataSet或是List等,也有可能将DataTable.DataSet或是List转换成JSON的,抽了点时间把 ...

  2. ABAP内表数据和JSON格式互转

    本程序演示ABAP内表数据如何转为JSON格式,以及JSON数据如何放入内表. 注:json字符串格式如:jsonstr = '[ {flag: "0",message: &quo ...

  3. xml与json格式互转

    最近要整一些报文测试的事情,可当前项目的请求报文格式却不统一,有XML也有JSON,为了一致性,决定统一用JSON格式处理. xmltodict : Makes working with XML fe ...

  4. postman做接口测试 application/x-www-form-urlencoded 格式与json格式互转

    背景:用postman做接口测试可以使用application/x-www-form-urlencoded请求,也可以使用json请求,接口文档如下: 请求参数 字段 类型 是否必填 注释 websi ...

  5. 通过http协议发送json格式请求并解析

    本人初入门径.代码略显粗糙,欢迎指点改正! 最近在做公司的项目的时候,需要和其他公司进行业务上的对接,对方直接扔过来一个协议用来开发,最近稍微看了一下,写了一个通过协议获取数据的方法 对方的协议内容部 ...

  6. JSon_零基础_008_将JSon格式的"数组"字符串转换为List集合

    将JSon格式的"数组"字符串转换为List集合. 应用此技术从一个json对象字符串格式中得到一个java对应的对象. JSONObject是一个“name.values”集合, ...

  7. JSon_零基础_005_将po(bean)对象集合List转换为JSon格式的对象字符串,返回给界面

    将po(bean)对象集合List转换为JSon格式的对象字符串,返回给界面 导入jar包: 编写:po(bean)代码: package com.west.webcourse.po; /** * 第 ...

  8. JSon_零基础_004_将Set集合对象转换为JSon格式的对象字符串,返回给界面

    将Set集合对象转换为JSon格式的对象字符串,返回给界面 需要导入的jar包: 编写:servlet: package com.west.webcourse.servlet; import java ...

  9. JSon_零基础_003_将Map集合对象转换为JSon格式的对象字符串,返回给界面

    将Map集合对象转换为JSon格式的对象字符串,返回给界面 需导入的jar包: 编写servlet: package com.west.webcourse.servlet; import java.i ...

随机推荐

  1. win10 下cuda 9.0 卸载

    1.首先 对于cuda8.0.cuda7.5的卸载都可以兼容 安装cuda9.0之后,电脑原来的NVIDIA图形驱动会被更新,NVIDIA Physx系统软件也会被更新(安装低版cuda可能不会被更新 ...

  2. 记录linux 生成crash dump文件步骤

    执行文件编译时加入-g 命令 例如 g++ -g test.cpp 查看当前系统限制情况 ulimit -a 设置crash dump 文件大小 ulimit -c unlimited unlimit ...

  3. LC 985. Sum of Even Numbers After Queries

    We have an array A of integers, and an array queries of queries. For the i-th query val = queries[i] ...

  4. 【python画图】

    1.热力图 import numpy as np import numpy.random import matplotlib.pyplot as plt # Generate some test da ...

  5. unity 读取灰度图生成三维地形并贴图卫星影像

    从 https://earthexplorer.usgs.gov/ 下载高程数据 从谷歌地球上保存对应地区卫星图像 从灰度图创建地形模型,并将卫星影像作为贴图 using System.Collect ...

  6. Flutter 获取网络数据及渲染列表

    还是通过Dio包调用远程接口获取数据,这里返回值为一个Future,这个对象支持一个等待回掉方法then. 示例代码如下: import 'package:flutter/material.dart' ...

  7. linux 怎样关闭x server?

    如果想切换至纯粹一点的命令字符console下,一般人会认为切换Ctrl+Alt+F1(或者F2-F6都可以). 默认下,Ctrl+Alt+F7是图形界面(当然,各个Linux发行版本会有所差异). ...

  8. Bootstrap 控制台示例

    1.打开https://getbootstrap.com/docs/4.3/examples/ 2.选择Dashboard 3.右键查看源代码,另存为 4.通过源代码界面下载JS和CSS 5.修改绝对 ...

  9. 《你必须知道的495个C语言问题》读书笔记之第4-7章:指针

    1. Q:为什么我不能对void *指针进行算术运算? A:因为编译器不知道所值对象的大小,而指针的算法运算总是基于所指对象的大小的. 2. Q:C语言可以“按引用传参”吗? A:不可以.严格来说,C ...

  10. spring websocket 使用@SendToUser

    spring websocket 使用@SendToUser 原文链接:https://blog.csdn.net/yingxiake/article/details/51224569 之前我们利用@ ...