001 using System;
002 using System.Collections.Generic;
003 using System.Linq;
004 using System.Text;
005 using System.Data;
006   
007 namespace Common
008
009   
010     public static class JsonExtensions
011     
012         #region DataSetToJson 扩展方法
013         /// <summary>
014         /// DataSetToJson 扩展方法
015         /// </summary>
016         /// <param name="ds">要传入的DataSet</param>
017         /// <param name="JsonName">Json的名称</param>
018         /// <param name="ParName">Json字段名称</param>
019         /// <returns>返回JSON字符串</returns>
020         public static string DataSetToJson(this DataSet ds, string JsonName, string[] ParName)
021         
022             try
023             
024                 if (ds == null
025                 
026                     return "DataSet Is Null ,So I Can't Do It To Json!"
027                 
028                 if (JsonName.Length < 1)
029                 
030                     return "You Set The Json Name Is Wrong!"
031                 
032                 if (ds.Tables[0].Columns.Count < ParName.Length)
033                 
034                     return "You Give The ParName Is Bigger Than DataSet Columns!"
035                 
036                 string josn = "{" + JsonName + ":["
037                 string temp = ""
038                 for (int j = 0; j < ds.Tables[0].Rows.Count; j++)
039                 
040                     temp = temp + "{"
041                     for (int i = 0; i < ParName.Length; i++)
042                     
043                         temp += "" + ParName[i] + ":\'" + ds.Tables[0].Rows[j][ParName[i]] + "\'"
044                         if (i != ParName.Length - 1)
045                         
046                             temp = temp + ","
047                         
048                     
049                     if (j == ds.Tables[0].Rows.Count - 1)
050                     
051                         temp = temp + "}"
052                     
053                     else
054                     
055                         temp = temp + "},"
056                     
057                 
058                 josn = josn + temp + "]}"
059                 return josn;
060             
061             catch (Exception ex)
062             
063                 return "Codeing is Error----" + ex.ToString();
064             
065   
066         
067   
068         #endregion
069   
070         #region  DataSetToJson 扩展方法
071         /// <summary>
072         /// DataSetToJson 扩展方法
073         /// </summary>
074         /// <param name="ds">要传入的DataSet</param>
075         /// <returns>返回JSON字符串<</returns>
076         public static string DataSetToJson(this DataSet ds)
077         
078             try
079             
080                 if (ds == null
081                 
082                     return "DataSet Is Null ,So I Can't Do It To Json!"
083                 
084                 string josn = "["
085                 string temp = ""
086                 for (int j = 0; j < ds.Tables[0].Rows.Count; j++)
087                 
088                     temp = temp + "{"
089                     for (int i = 0; i < ds.Tables[0].Columns.Count; i++)
090                     
091                         temp += "" + ds.Tables[0].Columns[i].ColumnName + ":\'" + ds.Tables[0].Rows[j][i] + "\'"
092                         if (i != ds.Tables[0].Columns.Count - 1)
093                         
094                             temp = temp + ","
095                         
096                     
097                     if (j == ds.Tables[0].Rows.Count - 1)
098                     
099                         temp = temp + "}"
100                     
101                     else
102                     
103                         temp = temp + "},"
104                     
105                 
106                 josn = josn + temp + "]"
107                 return josn;
108             
109             catch (Exception ex)
110             
111                 return "Codeing is Error----" + ex.ToString();
112             
113   
114         
115         #endregion
116     
117 }

DataSetToJson 扩展方法的更多相关文章

  1. .NET Core中间件的注册和管道的构建(3) ---- 使用Map/MapWhen扩展方法

    .NET Core中间件的注册和管道的构建(3) ---- 使用Map/MapWhen扩展方法 0x00 为什么需要Map(MapWhen)扩展 如果业务逻辑比较简单的话,一条主管道就够了,确实用不到 ...

  2. .NET Core中间件的注册和管道的构建(2)---- 用UseMiddleware扩展方法注册中间件类

    .NET Core中间件的注册和管道的构建(2)---- 用UseMiddleware扩展方法注册中间件类 0x00 为什么要引入扩展方法 有的中间件功能比较简单,有的则比较复杂,并且依赖其它组件.除 ...

  3. 为IEnumerable<T>添加RemoveAll<IEnumerable<T>>扩展方法--高性能篇

    最近写代码,遇到一个问题,微软基于List<T>自带的方法是public bool Remove(T item);,可是有时候我们可能会用到诸如RemoveAll<IEnumerab ...

  4. C#的扩展方法解析

    在使用面向对象的语言进行项目开发的过程中,较多的会使用到“继承”的特性,但是并非所有的场景都适合使用“继承”特性,在设计模式的一些基本原则中也有较多的提到. 继承的有关特性的使用所带来的问题:对象的继 ...

  5. 扩展方法(C#)

    扩展方法使你能够向现有类型“添加”方法,而无需创建新的派生类型.重新编译或以其他方式修改原始类型.扩展方法是一种特殊的静态方法,但可以像扩展类型上的实例方法一样进行调用. 下面的示例为String添加 ...

  6. 扩展方法解决LinqToSql Contains超过2100行报错问题

    1.扩展方法 using System; using System.Collections.Generic; using System.Linq; using System.Web; using Sy ...

  7. C#扩展方法

    扩展方法使您能够向现有类型“添加”方法,而无需创建新的派生类型.重新编译或以其他方式修改原始类型. 扩展方法就相当于一个马甲,给一个现有类套上,就可以为这个类添加其他方法了. 马甲必须定义为stati ...

  8. 枚举扩展方法获取枚举Description

    枚举扩展方法 /// <summary> /// 扩展方法,获得枚举的Description /// </summary> /// <param name="v ...

  9. 扩展方法 1 简单的string扩展方法

    这里是关于 String的简单扩展方法 (静态类 静态方法 this 类型 这里是string) static class Program { static void Main(string[] ar ...

随机推荐

  1. Asp.net MVC4高级编程学习笔记-视图学习第一课20171009

    首先解释下:本文只是对Asp.net MVC4高级编程这本书学习记录的学习笔记,书本内容感觉挺简单的,但学习容易忘记,因此在边看的同时边作下了笔记,可能其它朋友看的话没有情境和逻辑顺序还请谅解! 一. ...

  2. 醒醒吧!互联网的真正未来不是AI,更不是VR,AR,而是区块链

    这些力量并非命运,而是轨迹.他们提供的并不是我们将去向何方的预测,而是告诉我们,在不远的将来,我们会向那个方向前行,必然而然. ---凯文•凯利 文字与货币 人类在演化过程中,凭借智慧创造了无数事物, ...

  3. Windows下MySQL5.6.21安装步骤

    01.把 mysql-advanced-5.6.17-winx64.zip 解压到自定义 D:\mysql-5.6.17-W64 或 D:\mysql-advanced-5.6.17-winx64 目 ...

  4. 简单Elixir游戏服设计-创建玩家模型

    删除model.ex 创建玩家模型 player.ex, 简单化,只有唯一标识,昵称,金币,够用了. 选择 map 代表数据,是为了扩展数据结构,方便增加功能.struct也是可以的. add_num ...

  5. Java视频扩展知识 线程池的了解

     Java视频扩展知识   线程池的了解 1.简单介绍: Jdk1.5之后加入了java.util.concurrent包,这个包中主要介绍java中线程以及线程池的使用.为我们在开发中处理线程的 ...

  6. python codis集群客户端(二) - 基于zookeeper对实例创建与摘除

    在这一篇中我们实现了不通过zk来编写codis集群proxys的api,http://www.cnblogs.com/kangoroo/p/7481567.html 如果codis集群暴露zk给你的话 ...

  7. python装饰器 & flask 通过装饰器 实现 单点登录验证

    首先介绍装饰器,以下是一段标注了特殊输出的代码.用于帮助理解装饰器的调用过程. import time def Decorator_one(arg1): info = "\033[1;31; ...

  8. sublime Text 正则替换

    我遇到一个文章,需要把所有的 (数字) 换为 [数字] 于是我使用 Sublime Text的替换 首先,我们需要打开正则使用"Alt+R" 或打开"Ctrl+h&quo ...

  9. hdu4821 String

    您也可以在我的个人博客中阅读此文章:跳转 题意 一个字符串S 问其中有几个子串能满足以下条件:1.长度为m*l2.可以被分成m个l长的不同的子串问题就变成了如何快速的判断着m个子串是否存在相同的 思路 ...

  10. yii2之DetailView小部件

    DetailView小部件用于展示单条数据记录,可配置属性很少,使用也很简单,直接贴代码,一看就懂! yii小部件数据小部件DetailView的使用示例: <?= DetailView::wi ...