各种类型的Json格式化
using System;
using System.Collections.Generic;
using System.Text;
using System.Data;
using System.Reflection;
using System.Collections;
using System.Data.Common;
public
class
ConvertJson
{
#region 私有方法
/// <summary>
/// 过滤特殊字符
/// </summary>
private
static
string String2Json(String s)
{
StringBuilder sb =
new
StringBuilder();
for
(
int
i =
0
; i < s.Length; i++)
{
char
c = s.ToCharArray()[i];
switch
(c)
{
case
'\"'
:
sb.Append(
"\\\""
);
break
;
case
'\\'
:
sb.Append(
"\\\\"
);
break
;
case
'/'
:
sb.Append(
"\\/"
);
break
;
case
'\b'
:
sb.Append(
"\\b"
);
break
;
case
'\f'
:
sb.Append(
"\\f"
);
break
;
case
'\n'
:
sb.Append(
"\\n"
);
break
;
case
'\r'
:
sb.Append(
"\\r"
);
break
;
case
'\t'
:
sb.Append(
"\\t"
);
break
;
default
:
sb.Append(c);
break
;
}
}
return
sb.ToString();
}
/// <summary>
/// 格式化字符型、日期型、布尔型
/// </summary>
private
static
string StringFormat(string str, Type type)
{
if
(type == typeof(string))
{
str = String2Json(str);
str =
"\""
+ str +
"\""
;
}
else
if
(type == typeof(DateTime))
{
str =
"\""
+ str +
"\""
;
}
else
if
(type == typeof(bool))
{
str = str.ToLower();
}
else
if
(type != typeof(string) && string.IsNullOrEmpty(str))
{
str =
"\""
+ str +
"\""
;
}
return
str;
}
#endregion
#region List转换成Json
/// <summary>
/// List转换成Json
/// </summary>
public
static
string ListToJson<T>(IList<T> list)
{
object obj = list[
0
];
return
ListToJson<T>(list, obj.GetType().Name);
}
/// <summary>
/// List转换成Json
/// </summary>
public
static
string ListToJson<T>(IList<T> list, string jsonName)
{
StringBuilder Json =
new
StringBuilder();
if
(string.IsNullOrEmpty(jsonName)) jsonName = list[
0
].GetType().Name;
Json.Append(
"{\""
+ jsonName +
"\":["
);
if
(list.Count >
0
)
{
for
(
int
i =
0
; i < list.Count; i++)
{
T obj = Activator.CreateInstance<T>();
PropertyInfo[] pi = obj.GetType().GetProperties();
Json.Append(
"{"
);
for
(
int
j =
0
; j < pi.Length; j++)
{
Type type = pi[j].GetValue(list[i],
null
).GetType();
Json.Append(
"\""
+ pi[j].Name.ToString() +
"\":"
+ StringFormat(pi[j].GetValue(list[i],
null
).ToString(), type));
if
(j < pi.Length -
1
)
{
Json.Append(
","
);
}
}
Json.Append(
"}"
);
if
(i < list.Count -
1
)
{
Json.Append(
","
);
}
}
}
Json.Append(
"]}"
);
return
Json.ToString();
}
#endregion
#region 对象转换为Json
/// <summary>
/// 对象转换为Json
/// </summary>
/// <param name="jsonObject">对象</param>
/// <returns>Json字符串</returns>
public
static
string ToJson(object jsonObject)
{
string jsonString =
"{"
;
PropertyInfo[] propertyInfo = jsonObject.GetType().GetProperties();
for
(
int
i =
0
; i < propertyInfo.Length; i++)
{
object objectValue = propertyInfo[i].GetGetMethod().Invoke(jsonObject,
null
);
string value = string.Empty;
if
(objectValue is DateTime || objectValue is Guid || objectValue is TimeSpan)
{
value =
"'"
+ objectValue.ToString() +
"'"
;
}
else
if
(objectValue is string)
{
value =
"'"
+ ToJson(objectValue.ToString()) +
"'"
;
}
else
if
(objectValue is IEnumerable)
{
value = ToJson((IEnumerable)objectValue);
}
else
{
value = ToJson(objectValue.ToString());
}
jsonString +=
"\""
+ ToJson(propertyInfo[i].Name) +
"\":"
+ value +
","
;
}
jsonString.Remove(jsonString.Length -
1
, jsonString.Length);
return
jsonString +
"}"
;
}
#endregion
#region 对象集合转换Json
/// <summary>
/// 对象集合转换Json
/// </summary>
/// <param name="array">集合对象</param>
/// <returns>Json字符串</returns>
public
static
string ToJson(IEnumerable array)
{
string jsonString =
"["
;
foreach (object item in array)
{
jsonString += ToJson(item) +
","
;
}
jsonString.Remove(jsonString.Length -
1
, jsonString.Length);
return
jsonString +
"]"
;
}
#endregion
#region 普通集合转换Json
/// <summary>
/// 普通集合转换Json
/// </summary>
/// <param name="array">集合对象</param>
/// <returns>Json字符串</returns>
public
static
string ToArrayString(IEnumerable array)
{
string jsonString =
"["
;
foreach (object item in array)
{
jsonString = ToJson(item.ToString()) +
","
;
}
jsonString.Remove(jsonString.Length -
1
, jsonString.Length);
return
jsonString +
"]"
;
}
#endregion
#region DataSet转换为Json
/// <summary>
/// DataSet转换为Json
/// </summary>
/// <param name="dataSet">DataSet对象</param>
/// <returns>Json字符串</returns>
public
static
string ToJson(DataSet dataSet)
{
string jsonString =
"{"
;
foreach (DataTable table in dataSet.Tables)
{
jsonString +=
"\""
+ table.TableName +
"\":"
+ ToJson(table) +
","
;
}
jsonString = jsonString.TrimEnd(
','
);
return
jsonString +
"}"
;
}
#endregion
#region Datatable转换为Json
/// <summary>
/// Datatable转换为Json
/// </summary>
/// <param name="table">Datatable对象</param>
/// <returns>Json字符串</returns>
public
static
string ToJson(DataTable dt)
{
StringBuilder jsonString =
new
StringBuilder();
jsonString.Append(
"["
);
DataRowCollection drc = dt.Rows;
for
(
int
i =
0
; i < drc.Count; i++)
{
jsonString.Append(
"{"
);
for
(
int
j =
0
; j < dt.Columns.Count; j++)
{
string strKey = dt.Columns[j].ColumnName;
string strValue = drc[i][j].ToString();
Type type = dt.Columns[j].DataType;
jsonString.Append(
"\""
+ strKey +
"\":"
);
strValue = StringFormat(strValue, type);
if
(j < dt.Columns.Count -
1
)
{
jsonString.Append(strValue +
","
);
}
else
{
jsonString.Append(strValue);
}
}
jsonString.Append(
"},"
);
}
jsonString.Remove(jsonString.Length -
1
,
1
);
jsonString.Append(
"]"
);
return
jsonString.ToString();
}
/// <summary>
/// DataTable转换为Json
/// </summary>
public
static
string ToJson(DataTable dt, string jsonName)
{
StringBuilder Json =
new
StringBuilder();
if
(string.IsNullOrEmpty(jsonName)) jsonName = dt.TableName;
Json.Append(
"{\""
+ jsonName +
"\":["
);
if
(dt.Rows.Count >
0
)
{
for
(
int
i =
0
; i < dt.Rows.Count; i++)
{
Json.Append(
"{"
);
for
(
int
j =
0
; j < dt.Columns.Count; j++)
{
Type type = dt.Rows[i][j].GetType();
Json.Append(
"\""
+ dt.Columns[j].ColumnName.ToString() +
"\":"
+ StringFormat(dt.Rows[i][j].ToString(), type));
if
(j < dt.Columns.Count -
1
)
{
Json.Append(
","
);
}
}
Json.Append(
"}"
);
if
(i < dt.Rows.Count -
1
)
{
Json.Append(
","
);
}
}
}
Json.Append(
"]}"
);
return
Json.ToString();
}
#endregion
#region DataReader转换为Json
/// <summary>
/// DataReader转换为Json
/// </summary>
/// <param name="dataReader">DataReader对象</param>
/// <returns>Json字符串</returns>
public
static
string ToJson(DbDataReader dataReader)
{
StringBuilder jsonString =
new
StringBuilder();
jsonString.Append(
"["
);
while
(dataReader.Read())
{
jsonString.Append(
"{"
);
for
(
int
i =
0
; i < dataReader.FieldCount; i++)
{
Type type = dataReader.GetFieldType(i);
string strKey = dataReader.GetName(i);
string strValue = dataReader[i].ToString();
jsonString.Append(
"\""
+ strKey +
"\":"
);
strValue = StringFormat(strValue, type);
if
(i < dataReader.FieldCount -
1
)
{
jsonString.Append(strValue +
","
);
}
else
{
jsonString.Append(strValue);
}
}
jsonString.Append(
"},"
);
}
dataReader.Close();
jsonString.Remove(jsonString.Length -
1
,
1
);
jsonString.Append(
"]"
);
return
jsonString.ToString();
}
#endregion
}
各种类型的Json格式化的更多相关文章
- 使用Newtonsoft.json 解决 Asp.Net MVC DateTime类型数据Json格式化问题
解决思路 众所周知,MVC中调用的微软的组件JavaScriptSerialer...,格式DateTime类型数据需要在客户端专门解. 还知道,NewtonSoft.json可以“正确”的格式化Da ...
- JSON格式化与serialize序列化
一.JSON格式化 1. JSON是什么 JSON是一种数据的存储格式,用来沟通客户端Javascript和服务端PHP的交互.我们把用PHP生成JSON后的字符串传给前台Javascript,Jav ...
- ABP入门系列(8)——Json格式化
ABP入门系列目录--学习Abp框架之实操演练 讲完了分页功能,这一节我们先不急着实现新的功能.来简要介绍下Abp中Json的用法.为什么要在这一节讲呢?当然是做铺垫啊,后面的系列文章会经常和Json ...
- Asp.net WebAPi gzip压缩和json格式化
现在webapi越来越流行了,很多时候它都用来做接口返回json格式的数据,webapi原本是根据客户端的类型动态序列化为json和xml的,但实际很多时候我们都是序列化为json的,所以webapi ...
- yformater - chrome谷歌浏览器json格式化json高亮json解析插件
yformater是一款chrome浏览器插件,用来格式化(高亮)服务端接口返回的json数据. 实际上小菜并不是第一个写这种插件的,但是现有的chrome json格式化插件实在是不太好用,索性小菜 ...
- JavaScriptSerializer 中的匿名类型 转json
二:JavaScriptSerializer 中的匿名类型 这个类型我想大家都清楚,不过性能更高的方式应该是用JsonConvert吧,但这个不是本篇讨论的话题,我们重点来看看匿名类型的Json序列化 ...
- struts2 中的 result 返回类型是 json 的配置问题
struts2 中的 result 返回类型是 json 的配置问题 1.引入包(本文中的包全部引自struts-2.1.8.1\lib): struts2-json-plugin-2.1.8.1.j ...
- JSON格式化 JSON美化 输出到html
{"promotion_details":{"promotion_detail":[{"discount_fee":"22.20& ...
- asp.net中json格式化及在js中解析json
类: public class UploadDocumentItem { public UploadDocumentItem() { } public string DocMuid { get; se ...
随机推荐
- python中调用多线程加速处理文件
问题背景是这样的,我有一批需要处理的文件,对于每一个文件,都需要调用同一个函数进行处理,相当耗时 有没有加速的办法呢?当然有啦,比如说你将这些文件分成若干批,每一个批次都调用自己写的python脚本进 ...
- Sublime 修改快捷键
Preferences-Key Bindings-User 添加一行: { "keys": ["ctrl+d"], "command": & ...
- [LeetCode&Python] Problem 551. Student Attendance Record I
You are given a string representing an attendance record for a student. The record only contains the ...
- multi-head attention
■ 论文 | Attention Is All You Need ■ 链接 | https://www.paperweekly.site/papers/224 ■ 源码 | https://githu ...
- PDO数据库引擎
PDO概述1.PDO是一种数据库访问抽象层,你不必使用以前的 mysqli_xx 之类只能访问 mysql数据库.使用PDO可以连接mysql.msssql.oracle等等,而不必重写代码.2.PD ...
- 08 正则表达式,Math类,Random,System类,BigInteger,BigDecimal,Date,DateFormat,Calendar
正则表达式: 是指一个用来描述或者匹配一系列符合某个语法规则的字符串的单个字符串.其实就是一种规则.有自己特殊的应用. public class Demo2_Regex { public sta ...
- c#接口与虚函数的实验报告
1)定义Student类,用string型变量name存储学生姓名,用int型变量age存储学生年龄.Student类实现IComparable接口.要求从键盘输入学生的姓名和年龄,并注意可能出现的异 ...
- js获取元素得几种情况
HTML代码 <div class="divClass" name="myClass"> <input type="password ...
- 浅谈log4j-2
//配置日志输出的定义,主要有三点:1:输出什么级别的日志信息,2:将日志信息输出到那里,3:输出的日志以什么格式展示 public static void main(String[] args) { ...
- jsp中的include静态包含与动态包含,
d动态包含与静态包含的最大区别是 静态包含:<%@ include file = "文件名.jsp"%>,在<body>的标签外定义.在没有编译的时候,两个 ...