ExpandoObject动态类生成属性转json
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的更多相关文章
- Android动态类生成预加载-dexmaker使用
一.dexmaker简单介绍 dexmaker是运行在Android Dalvik VM上,利用Java编写,来动态生成DEX字节码的API.如果读者了解AOP编程的话,应该听说过cglib or A ...
- Android 通过Java代码生成创建界面。动态生成View,动态设置View属性。addRules详解
废话不多说,本文将会层层深入给大家讲解如何动态的生成一个完整的界面. 本文内容: Java代码中动态生成View Java代码中动态设置View的位置,以及其他的属性 LayoutParams详解 一 ...
- XML之自动生成类,添加,修改,删除类的属性
1. class ClassHelperDemo { public static void Main() { #region 演示一:动态生成类. //生成一个类t. Type t = ClassHe ...
- json.net(Json.NET - Newtonsoft)利用动态类解析json字符串
将对象转换为字符串很简单,唯一要注意的点就是为了避免循环要在需要的字段上添加jsonignore属性.可以参照这篇博文:http://www.mamicode.com/info-detail-1456 ...
- 速战速决 (5) - PHP: 动态地创建属性和方法, 对象的复制, 对象的比较, 加载指定的文件, 自动加载类文件, 命名空间
[源码下载] 速战速决 (5) - PHP: 动态地创建属性和方法, 对象的复制, 对象的比较, 加载指定的文件, 自动加载类文件, 命名空间 作者:webabcd 介绍速战速决 之 PHP 动态地创 ...
- mvc中动态给一个Model类的属性设置验证
原文:mvc中动态给一个Model类的属性设置验证 在mvc中有自带的验证机制,比如如果某个字段的类型是数字或者日期,那么用户在输入汉字或者英文字符时,那么编译器会自动验证并提示用户格式不正确,不过这 ...
- EntityFramework4.5使用Expression类创建动态查询及动态查询导航属性
创建动态查询 想在项目中实现一个灵活的动态查询类,参考http://www.cnblogs.com/lyj/archive/2008/03/25/1122157.html和http://www.cnb ...
- python 反射 动态导入模块 类attr属性
1.反射 hasattr getattr delattr setattr 优点:事先定义好接口,接口只有在被完成后才能真正执行,这实现了即插即用,这其实是一种“后期绑定”,即先定义好接口, 然后是再去 ...
- 解决SpringDataJpa实体类中属性顺序与数据库中生成字段顺序不一致的问题
一.在application.yml配置中添加数据库根据实体类自动创建数据库表的配置(这里数据库采用MySQL数据库) jpa: database: MYSQL show-sql: true #Hib ...
随机推荐
- 常用MIME类型(Flv,Mp4的mime类型设置)(转载)
转载地址:http://www.cuplayer.com/player/Help/2011/0625/83.html 也许你会在纳闷,为什么我上传了flv或MP4文件到服务器,可输入正确地址通过htt ...
- 关于opengl库
The 64-bit OpenGL import library is included in the Windows SDK and gets installed to %ProgramFiles% ...
- linux yum安装jdk
>>>>>>>>>> 实例: yum安装jdk 1.查看当前的jdk版本,并卸载 (注1:rpm -qa ###解释:查询所有安装的rpm包 ...
- Node.js学习之简介
1.简单的说Node.js就是运行在服务端的javaScript: 2.Node.js是一个基于Chrome javaScript运行时建立的一个平台: 3.Node.js是一个事件驱动I/O服务端J ...
- 关于HTML5的拖拽
不介绍具体情况,先看API,注意看后面括号的说明 dragstart:拖拽开始(应用于被拖拽对象) drag:拖拽中(应用于被拖拽对象) dragenter:拖拽到指定位置(应用于拖拽目标) drag ...
- xml转义字符
解析XML文件时,如果有多个转义学符可以用 <![CDATA[含有转义字符的内容]]
- Service Locator 服务定位模式
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...
- java的poi技术读取Excel[2003-2007,2010]
这篇blog主要是讲述java中poi读取excel,而excel的版本包括:2003-2007和2010两个版本, 即excel的后缀名为:xls和xlsx. 读取excel和MySQL相关: ja ...
- Linux下面桌面的安装
挂载光盘后配置yum文件,配置后 使用yum grouplist 命令 查看组 用yum install '"GNOM桌面组 输入 init 5 即可进入桌面模式 0 关机 3命令行级 ...
- CNUOJ 0486 800401反质数
难度级别:A: 运行时间限制:1000ms: 运行空间限制:51200KB: 代码长度限制:2000000B 试题描述 将正整数 x 的约数个数表示为 g(x).例如,g(1)=1,g(4)=3, g ...