using System;
 using System.Collections;
 using System.Collections.Generic;
 using System.Collections.ObjectModel;
 using System.ComponentModel;
 using System.Data;
 using System.Drawing;
 using System.Dynamic;
 using System.Linq;
 using System.Text;
 using System.Threading.Tasks;
 using System.Web.Script.Serialization;
 using System.Windows.Forms;
 using Newtonsoft.Json;

 namespace WindowsFormsApplication2
 {

     public partial class Form1 : Form
     {
         private List<Test> l = new List<Test>();

         public Form1()
         {
             InitializeComponent();
         }
         private void button3_Click(object sender, EventArgs e)
         {
             List<string> rowname = new List<string>();
             List<string> colname = new List<string>();
             List<IDictionary<String, Object>> l1 = new List<IDictionary<String, Object>>();

             //获得行名称
             ; i < l.Count; i++)
             {
                 bool IsExist = true;
                 ; j < rowname.Count; j++)
                 {
                     if (rowname[j].ToString() == l[i].Name)
                     {
                         IsExist = false;
                         break;
                     }
                 }
                 if (IsExist)
                     rowname.Add(l[i].Name);
             }

            // 获得列名称
             ; i < l.Count; i++)
             {
                 bool IsExist = true;
                 ; j < colname.Count; j++)
                 {
                     if (colname[j].ToString() == l[i].Type.ToString())
                     {
                         IsExist = false;
                         break;
                     }
                 }
                 if (IsExist)
                     colname.Add(l[i].Type.ToString());
             }
             colname.Insert(,"name");

             //数据转换
             ; i < rowname.Count; i++)
             {
                 dynamic exobj = new ExpandoObject();
                 var obj = (IDictionary<String, Object>) exobj;
                 obj.Add("name", rowname[i]);
                 List<Test> t = l.Where(c => c.Name.Equals(rowname[i])).ToList();

                 ; j < t.Count(); j++)
                 {
                     obj.Add(t[j].Type.ToString(), t[j].Money);
                 }
                 l1.Add(obj);
             }

             DataTable dt = new DataTable("dt");

             //创建列
             ; i < colname.Count; i++)
             {
                 dt.Columns.Add(colname[i]);
             }

             //创建行
             ; i < l1.Count; i++)
             {
                 DataRow r = dt.NewRow();
                 ; j < dt.Columns.Count; j++)
                 {
                     r[j] = l1[i][colname[j]];
                 }

                 dt.Rows.Add(r);
             }
             dataGridView2.DataSource = dt;

             ]);
             MessageBox.Show(json1);

         }

         private void Form1_Load(object sender, EventArgs e)
         {
             ; i < ; i++)
             {
                 Test t = new Test();
                 t.Type = ;
                 t.Name = "nametype" + i.ToString();
                 t.Money =  + i;
                 l.Add(t);
             }
             ; i < ; i++)
             {
                 Test t = new Test();
                 t.Type = ;
                 t.Name = "nametype" + i.ToString();
                 t.Money =  + i;
                 l.Add(t);
             }
             ; i < ; i++)
             {
                 Test t = new Test();
                 t.Type = ;
                 t.Name = "nametype" + i.ToString();
                 t.Money =  + i;
                 l.Add(t);
             }

             dataGridView1.DataSource = l;
         }

         public class Test
         {
             public string Name { get; set; }
             public int Type { get; set; }
             public decimal Money { get; set; }
         }
     }
 }

ExpandoObject动态类生成属性转json的更多相关文章

  1. Android动态类生成预加载-dexmaker使用

    一.dexmaker简单介绍 dexmaker是运行在Android Dalvik VM上,利用Java编写,来动态生成DEX字节码的API.如果读者了解AOP编程的话,应该听说过cglib or A ...

  2. Android 通过Java代码生成创建界面。动态生成View,动态设置View属性。addRules详解

    废话不多说,本文将会层层深入给大家讲解如何动态的生成一个完整的界面. 本文内容: Java代码中动态生成View Java代码中动态设置View的位置,以及其他的属性 LayoutParams详解 一 ...

  3. XML之自动生成类,添加,修改,删除类的属性

    1. class ClassHelperDemo { public static void Main() { #region 演示一:动态生成类. //生成一个类t. Type t = ClassHe ...

  4. json.net(Json.NET - Newtonsoft)利用动态类解析json字符串

    将对象转换为字符串很简单,唯一要注意的点就是为了避免循环要在需要的字段上添加jsonignore属性.可以参照这篇博文:http://www.mamicode.com/info-detail-1456 ...

  5. 速战速决 (5) - PHP: 动态地创建属性和方法, 对象的复制, 对象的比较, 加载指定的文件, 自动加载类文件, 命名空间

    [源码下载] 速战速决 (5) - PHP: 动态地创建属性和方法, 对象的复制, 对象的比较, 加载指定的文件, 自动加载类文件, 命名空间 作者:webabcd 介绍速战速决 之 PHP 动态地创 ...

  6. mvc中动态给一个Model类的属性设置验证

    原文:mvc中动态给一个Model类的属性设置验证 在mvc中有自带的验证机制,比如如果某个字段的类型是数字或者日期,那么用户在输入汉字或者英文字符时,那么编译器会自动验证并提示用户格式不正确,不过这 ...

  7. EntityFramework4.5使用Expression类创建动态查询及动态查询导航属性

    创建动态查询 想在项目中实现一个灵活的动态查询类,参考http://www.cnblogs.com/lyj/archive/2008/03/25/1122157.html和http://www.cnb ...

  8. python 反射 动态导入模块 类attr属性

    1.反射 hasattr getattr delattr setattr 优点:事先定义好接口,接口只有在被完成后才能真正执行,这实现了即插即用,这其实是一种“后期绑定”,即先定义好接口, 然后是再去 ...

  9. 解决SpringDataJpa实体类中属性顺序与数据库中生成字段顺序不一致的问题

    一.在application.yml配置中添加数据库根据实体类自动创建数据库表的配置(这里数据库采用MySQL数据库) jpa: database: MYSQL show-sql: true #Hib ...

随机推荐

  1. C++ 基础知识复习(一)

    数据类型,常量与变量部分:(发现有些点竟然这么多年第一次发现) C++基本数据类型有哪些: 答:整型,浮点型,void型. 注:其他各种数据类型均是这三种类型的扩充,另外void类型在实际程序中经常用 ...

  2. HTML5编码规范

    为每个 HTML 页面的第一行添加标准模式(standard mode)的声明,这样能够确保在每个浏览器中拥有一致的展现. 用两个空格来代替制表符(tab) -- 这是唯一能保证在所有环境下获得一致展 ...

  3. LeetCode——Balanced Binary Tree(判断是否平衡二叉树)

    问题: Given a binary tree, determine if it is height-balanced. For this problem, a height-balanced bin ...

  4. html学习第一天笔记——第六章节

    <input type="reset" value="重置"> 使用重置按钮,重置表单信息<input type="submit&q ...

  5. web请求的拦截与处理

    1,特定请求的拦截:spring或struct2的拦截器,指定拦截模式和处理的servlet: 2,非特定的恶意非法请求,web.xml的error-page元素可以接受tomcat返回的错误代码,并 ...

  6. solr连接数据库配置

    一般要搜索的信息都是被存储在数据库里面的,但是我们不能直接搜数据库,所以只有借助Solr将要搜索的信息在搜索服务器上进行索引,然后在客户端供客户使用. 一.链接数据库 1. SQL配置 拿SQL Se ...

  7. 2016最新 wamp2.5+windows 10安装CoedSgniffer代码格式检查:

    14:59 2016/1/112016最新 wamp2.5+windows 10安装CoedSgniffer代码格式检查:注意问题:1.手动安装2.5.0和pear安装方式都成功但是执行时无任何反映, ...

  8. javascript压缩工具

    Google Closure Compiler : http://code.google.com/closure/compiler/ YUI Compressor : http://developer ...

  9. HttpPostedFile类的使用方法

    HttpPostedFile注意事项: (1)    HttpPostedFile提供对客户端已上载的单独文件的访问. (2)    对于客户端已上载的文件,最好先保存到服务器,再访问:而不是直接访问 ...

  10. maven模块

    用maven无它,唯方便而. 模块依赖可以用来做一些公共模块,多个工程调用. 先子模块 install 或者package.在父模块install