JsonParse类
using System.Data;
using Newtonsoft.Json;
using Newtonsoft.Json.Converters;
using System;
using System.Text; namespace es.Common
{
public class JsonParse : IDisposable
{
#region 释放资源
bool dis;
public void Dispose()
{
Dispose(true);
GC.SuppressFinalize(this);
}
protected virtual void Dispose(bool disposing)
{
if (dis) return;
if (disposing)
dis = true;
}
~JsonParse() { Dispose(false); }
#endregion
/// <summary>
/// DataTable转换为json
/// </summary>
/// <param name="dt"></param>
/// <returns></returns>
public string ToJson(DataTable dt)
{
if (dt != null && dt.Rows.Count > ) return JsonConvert.SerializeObject(dt, new DataTableConverter(), new IsoDateTimeConverter { DateTimeFormat = "yyyy-MM-dd" });
else return null;
}
/// <summary>
/// DataTable转换为json
/// </summary>
/// <param name="dt"></param>
/// <param name="format">时间格式:默认:“yyyy-MM-dd hh:mm:ss”</param>
/// <returns></returns>
public string ToJson(DataTable dt, string format)
{
format = string.IsNullOrEmpty(format) ? "yyyy-MM-dd hh:mm:ss" : format;
if (dt != null && dt.Rows.Count > ) return JsonConvert.SerializeObject(dt, new DataTableConverter(), new IsoDateTimeConverter { DateTimeFormat = format });
else return null;
}
/// <summary>
/// 表格形式转换为json
/// </summary>
/// <param name="dt"></param>
/// <param name="total"></param>
/// <returns></returns>
public string ToTablePage(DataTable dt, int total)
{
if (total > && dt.Rows.Count > ) return "{\"total\":" + total + ",\"content\":" + this.ToJson(dt) + "}";
else return null;
}
/// <summary>
/// layui框架table模块数据转换为json
/// </summary>
/// <param name="dt"></param>
/// <param name="count"></param>
/// <returns></returns>
public string ToLayuiTable(DataTable dt, int count)
{
if (count > && dt.Rows.Count > ) return "{\"code\":0,\"msg\":\"\",\"count\":" + count + ",\"data\":" + this.ToJson(dt) + "}";
else return "{\"code\":-1,\"msg\":\"没有符合条件的记录\",\"count\":0,\"data\":[]}";
}
/// <summary>
/// layui框架table模块数据转换为json
/// </summary>
/// <param name="dt"></param>
/// <param name="count"></param>
/// <param name="format"></param>
/// <returns></returns>
public string ToLayuiTable(DataTable dt, int count, string format)
{
if (count > && dt.Rows.Count > ) return "{\"code\":0,\"msg\":\"\",\"count\":" + count + ",\"data\":" + this.ToJson(dt, format) + "}";
else return "{\"code\":-1,\"msg\":\"没有符合条件的记录\",\"count\":0,\"data\":[]}";
}
/// <summary>
/// 获得带有children的json字符串,字段里必须有(id,pid)两个字段
/// </summary>
/// <param name="dt">DataTable</param>
/// <param name="id">父级id</param>
/// <returns></returns>
public string ToChildren(DataTable dt, int id)
{
if (dt != null && dt.Rows.Count > )
{
DataRow[] rows = dt.Select("pid=" + id);
if (rows.Length == ) return string.Empty;
StringBuilder str = new StringBuilder();
foreach (DataRow row in rows)
{
str.Append("{");
for (int i = ; i < row.Table.Columns.Count; i++)
{
if (row.Table.Columns[i].ColumnName != "pid")
{
if (i != ) str.Append(",");
str.Append("\"");
str.Append(row.Table.Columns[i].ColumnName);
str.Append("\":\"");
str.Append(row[i]);
str.Append("\"");
}
}
if (ToChildren(dt, (int)row["id"]).Length > )
{
str.Append(",\"children\":");
str.Append(ToChildren(dt, (int)row["id"]));
str.Append("},");
}
else
{
str.Append("},");
}
}
string json = str[str.Length - ] == ',' ? str.ToString(, str.Length - ) : str.ToString();
return "[" + json + "]";
}
else
{
return null;
}
}
}
}
JsonParse类的更多相关文章
- Java类的继承与多态特性-入门笔记
相信对于继承和多态的概念性我就不在怎么解释啦!不管你是.Net还是Java面向对象编程都是比不缺少一堂课~~Net如此Java亦也有同样的思想成分包含其中. 继承,多态,封装是Java面向对象的3大特 ...
- C++ 可配置的类工厂
项目中常用到工厂模式,工厂模式可以把创建对象的具体细节封装到Create函数中,减少重复代码,增强可读和可维护性.传统的工厂实现如下: class Widget { public: virtual i ...
- Android请求网络共通类——Hi_博客 Android App 开发笔记
今天 ,来分享一下 ,一个博客App的开发过程,以前也没开发过这种类型App 的经验,求大神们轻点喷. 首先我们要创建一个Andriod 项目 因为要从网络请求数据所以我们先来一个请求网络的共通类. ...
- ASP.NET MVC with Entity Framework and CSS一书翻译系列文章之第二章:利用模型类创建视图、控制器和数据库
在这一章中,我们将直接进入项目,并且为产品和分类添加一些基本的模型类.我们将在Entity Framework的代码优先模式下,利用这些模型类创建一个数据库.我们还将学习如何在代码中创建数据库上下文类 ...
- ASP.NET Core 折腾笔记二:自己写个完整的Cache缓存类来支持.NET Core
背景: 1:.NET Core 已经没System.Web,也木有了HttpRuntime.Cache,因此,该空间下Cache也木有了. 2:.NET Core 有新的Memory Cache提供, ...
- .NET Core中间件的注册和管道的构建(2)---- 用UseMiddleware扩展方法注册中间件类
.NET Core中间件的注册和管道的构建(2)---- 用UseMiddleware扩展方法注册中间件类 0x00 为什么要引入扩展方法 有的中间件功能比较简单,有的则比较复杂,并且依赖其它组件.除 ...
- Java基础Map接口+Collections工具类
1.Map中我们主要讲两个接口 HashMap 与 LinkedHashMap (1)其中LinkedHashMap是有序的 怎么存怎么取出来 我们讲一下Map的增删改查功能: /* * Ma ...
- PHP-解析验证码类--学习笔记
1.开始 在 网上看到使用PHP写的ValidateCode生成验证码码类,感觉不错,特拿来分析学习一下. 2.类图 3.验证码类部分代码 3.1 定义变量 //随机因子 private $char ...
- C# 多种方式发送邮件(附帮助类)
因项目业务需要,需要做一个发送邮件功能,查了下资料,整了整,汇总如下,亲测可用- QQ邮箱发送邮件 #region 发送邮箱 try { MailMessage mail = new MailMess ...
随机推荐
- angularjs file upload插件使用总结
之前由于项目需要,决定使用angularjs做前端开发,在前两个项目中都有文件上传的功能,因为是刚接触angularjs,所以对一些模块和模块间的依赖不是很了解.都是由其他大神搭好框架,我只做些简单的 ...
- Application.messagebox对话框样式
if Application.MessageBox('删除不能恢复,确认删除吗?', '删除提示', MB_OKCANCEL + MB_ICONQUESTION)=mrOk thenbegin Sho ...
- css中单位px和em,rem的区别
PX:PX实际上就是像素,用PX设置字体大小时,比较稳定和精确.但是这种方法存在一个问题,当用户在浏览器中浏览我们制作的Web页面时,如果改变了浏览器的缩放,这时会使用我们的Web页面布局被打破.这样 ...
- js string.format 方法
String.prototype.format = function(args) { var result = this; if (arguments.length > 0) { if (arg ...
- python的random模块及加权随机算法的python实现
random是用于生成随机数的,我们可以利用它随机生成数字或者选择字符串. random.seed(x)改变随机数生成器的种子seed. 一般不必特别去设定seed,Python会自动选择seed. ...
- 用VLC做流媒体服务器
VLC确切来说只是个播放器,是videolan的开源产品,videolan原来还有一个VLM,是服务器端,专门用来做流媒体服务器的,但是现在VLM的功能已经都集成进VLC了,所以也就可以用VLC来做流 ...
- 股神小D
题目大意: 给定一棵树,每一条边有$L,R$两种权值,求有多少条路径满足$\max(L)\leq\min(R)$. 解法$1-$点分治$+$二维数点 统计树上的路径应首先想到点分治,我们很显然可以搜出 ...
- luogu1901 发射站
单调栈 正着插一遍反着插一遍 记录每个点左边右边第一个比他高的... yyc太强辣 #include<iostream> #include<cstdlib> #include& ...
- bzoj 4631: 踩气球 线段树
题目: Description 六一儿童节到了, SHUXK 被迫陪着M个熊孩子玩一个无聊的游戏:有N个盒子从左到右排成一排,第i个盒子里装着Ai个气球. SHUXK 要进行Q次操作,每次从某一个盒子 ...
- Winform程序实现多显示屏、多屏幕显示的2种方法
这篇文章主要介绍了Winform窗口实现多显示屏显示的2种方法,本文直接给出了实现代码,并对其中的一些重要参数做了解释,需要的朋友可以参考下. 一台主机连接了2台显示器(2个显卡),要求一个程序的两个 ...