仅供个人学习

需要先引入System.CodeDom nuget包

 using CodeGenerate.Entities;
using System;
using System.CodeDom;
using System.CodeDom.Compiler;
using System.Collections.Generic;
using System.Reflection;
using System.Text; namespace CodeGenerate
{
public class GenerateCS
{
/// <summary>
/// 生成的类里面只有字段
/// </summary>
/// <param name="namespaceName"></param>
/// <param name="className"></param>
/// <param name="classType"></param>
/// <param name=""></param>
public static void FieldGenerate(string namespaceName, string className, TypeAttributes classType, string FileName, List<ClassFieldInfo> classInfos)
{
CodeCompileUnit unit = new CodeCompileUnit(); //准备必要的命名空间(这个是指要生成的类的空间)
CodeNamespace sampleNamespace = new CodeNamespace(); //导入必要的命名空间
//sampleNamespace.Imports.Add(new CodeNamespaceImport("System")); //设置命名空间的名称
sampleNamespace.Name = namespaceName; //准备要生成的类的定义
CodeTypeDeclaration Customerclass = new CodeTypeDeclaration(className); //指定这是一个Class
Customerclass.IsClass = true;
Customerclass.TypeAttributes = classType;
//Customerclass.Attributes = MemberAttributes.Public | MemberAttributes.Const; //把这个类放在这个命名空间下
sampleNamespace.Types.Add(Customerclass); //把该命名空间加入到编译器单元的命名空间集合中
unit.Namespaces.Add(sampleNamespace); //这是输出文件名称
string outputFile = FileName; //添加字段
foreach (ClassFieldInfo item in classInfos)
{
CodeMemberField field = new CodeMemberField(item.FieldType, item.FiledName);
field.Attributes = item.FiledMemberAttributes;
field.Comments.Add(new CodeCommentStatement(item.FieldComments));
//field.InitExpression = new CodeFieldReferenceExpression(new CodeTypeReferenceExpression("System.Int64"), "12 * 1024 * 1024");
field.InitExpression = new CodeFieldReferenceExpression(null, item.FileValue);
Customerclass.Members.Add(field);
} //生成代码
CodeDomProvider provider = CodeDomProvider.CreateProvider("CSharp");
CodeGeneratorOptions options = new CodeGeneratorOptions();
options.BracingStyle = "C";
options.BlankLinesBetweenMembers = true;
using (System.IO.StreamWriter sw = new System.IO.StreamWriter(outputFile))
{
provider.GenerateCodeFromCompileUnit(unit, sw, options);
}
} public static void PropertiesGenerate(string namespaceName, string className, TypeAttributes classType, string FileName, List<ClassPropertyInfo> classInfos)
{
CodeCompileUnit unit = new CodeCompileUnit(); //准备必要的命名空间(这个是指要生成的类的空间)
CodeNamespace sampleNamespace = new CodeNamespace(); //导入必要的命名空间
//sampleNamespace.Imports.Add(new CodeNamespaceImport("System")); //设置命名空间的名称
sampleNamespace.Name = namespaceName; //准备要生成的类的定义
CodeTypeDeclaration Customerclass = new CodeTypeDeclaration(className); //指定这是一个Class
Customerclass.IsClass = true;
Customerclass.TypeAttributes = classType;
//Customerclass.Attributes = MemberAttributes.Public | MemberAttributes.Const; //把这个类放在这个命名空间下
sampleNamespace.Types.Add(Customerclass); //把该命名空间加入到编译器单元的命名空间集合中
unit.Namespaces.Add(sampleNamespace); //这是输出文件名称
string outputFile = FileName; foreach(ClassPropertyInfo item in classInfos)
{
CodeMemberProperty property = new CodeMemberProperty();
property.Attributes = item.PropertyMemberAttributes;
property.Name = item.PropertyName;
property.HasGet = item.IsHaveGet;
property.HasSet = item.IsHaveSet;
property.Type = new CodeTypeReference(item.PropertyType);
property.Comments.Add(new CodeCommentStatement(item.PropertyComments));
//property.GetStatements.Add(new CodeMethodReturnStatement(new CodeFieldReferenceExpression(new CodeThisReferenceExpression(), "_Id")));
//property.SetStatements.Add(new CodeAssignStatement(new CodeFieldReferenceExpression(new CodeThisReferenceExpression(), "_Id"), new CodePropertySetValueReferenceExpression()));
Customerclass.Members.Add(property);
} //生成代码
CodeDomProvider provider = CodeDomProvider.CreateProvider("CSharp");
CodeGeneratorOptions options = new CodeGeneratorOptions();
options.BracingStyle = "C";
options.BlankLinesBetweenMembers = true;
using (System.IO.StreamWriter sw = new System.IO.StreamWriter(outputFile))
{
provider.GenerateCodeFromCompileUnit(unit, sw, options);
}
}
}
}
static void Generate(Dictionary<string, string> dic)
{
CodeCompileUnit unit = new CodeCompileUnit(); //准备必要的命名空间(这个是指要生成的类的空间)
CodeNamespace sampleNamespace = new CodeNamespace(); //导入必要的命名空间
//sampleNamespace.Imports.Add(new CodeNamespaceImport("System")); //设置命名空间的名称
sampleNamespace.Name = "FiiiChain.Consensus"; //准备要生成的类的定义
CodeTypeDeclaration Customerclass = new CodeTypeDeclaration("BlockSetting"); //指定这是一个Class
Customerclass.IsClass = true;
Customerclass.TypeAttributes = TypeAttributes.Public;
//Customerclass.Attributes = MemberAttributes.Public | MemberAttributes.Const; //把这个类放在这个命名空间下
sampleNamespace.Types.Add(Customerclass); //把该命名空间加入到编译器单元的命名空间集合中
unit.Namespaces.Add(sampleNamespace); //这是输出文件
string outputFile = "BlockSetting.cs"; //添加字段
foreach (KeyValuePair<string, string> item in dic)
{
CodeMemberField field = new CodeMemberField(typeof(long), item.Key);
field.Attributes = MemberAttributes.Public | MemberAttributes.Const;
//field.Comments.Add(new CodeCommentStatement("Max block size is 12 MB"));
//field.InitExpression = new CodeFieldReferenceExpression(new CodeTypeReferenceExpression("System.Int64"), "12 * 1024 * 1024");
field.InitExpression = new CodeFieldReferenceExpression(null, item.Value);
Customerclass.Members.Add(field);
}
//添加属性 CodeMemberProperty property = new CodeMemberProperty();
property.Attributes = MemberAttributes.Public | MemberAttributes.Final;
property.Name = "Id";
property.HasGet = true;
property.HasSet = true;
property.Type = new CodeTypeReference(typeof(System.String));
property.Comments.Add(new CodeCommentStatement("这是Id属性"));
//property.GetStatements.Add(new CodeMethodReturnStatement(new CodeFieldReferenceExpression(new CodeThisReferenceExpression(), "_Id1")));
//property.SetStatements.Add(new CodeAssignStatement(new CodeFieldReferenceExpression(new CodeThisReferenceExpression(), "_Id2"), new CodePropertySetValueReferenceExpression()));
Customerclass.Members.Add(property); //添加方法(使用CodeMemberMethod)--此处略 //添加构造器(使用CodeConstructor) --此处略 //添加程序入口点(使用CodeEntryPointMethod) --此处略 //添加事件(使用CodeMemberEvent) --此处略 //添加特征(使用 CodeAttributeDeclaration)
Customerclass.CustomAttributes.Add(new CodeAttributeDeclaration(new CodeTypeReference(typeof(SerializableAttribute)))); //生成代码
CodeDomProvider provider = CodeDomProvider.CreateProvider("CSharp");
CodeGeneratorOptions options = new CodeGeneratorOptions();
options.BracingStyle = "C";
options.BlankLinesBetweenMembers = true;
using (System.IO.StreamWriter sw = new System.IO.StreamWriter(outputFile))
{
provider.GenerateCodeFromCompileUnit(unit, sw, options);
}
}

参考文章:http://www.cnblogs.com/xszjk/articles/6414099.html

CodeDom生成类文件的更多相关文章

  1. Mybatis逆向工程生成类文件

    首先,我们需要建好相关文件夹目录: 然后,编写执行脚本 generator.xml : 1 <?xml version="1.0" encoding="UTF-8& ...

  2. C# wsdl.exe 生成类文件

    wsdl.exe D:\XXX\demand\demand.\wsdl\XXX.wsdl /\wsdl\class 在 vs tools:Developer Command Prompt For VS ...

  3. T4 模板自动生成带注释的实体类文件 - 只需要一个 SqlSugar.dll

    生成实体就是这么简单,只要建一个T4文件和 文件夹里面放一个DLL. 使用T4模板教程 步骤1 创建T4模板 ,一定要自已新建,把T4代码复制进去,好多人因为用我现成的T4报错(原因不明) 点击添加文 ...

  4. 使用 xsd.exe 命令工具将 xsd 架构生成 类(CS) 文件

    vs自带命令行工具 命令:xsd  xml文件路径 C:\Program Files (x86)\Microsoft Visual Studio 9.0\VC>xsd d:Scheme.xml ...

  5. 使用CodeSmith快速生成映射文件和映射类

    一 CodeSmith简介 本文以表自动生成NHibernate的映射文件和映射类的实例来说明一下本软件的使用方法. CodeSmith是一种基于模板的代码生成工具,其使用类似于ASP.NET的语法来 ...

  6. 命令行下使用javah命令生成.h文件,出现“错误: 无法访问android.app.Activity 找不到android.app.Activity的类文件”的解决方法

    在学习NDK中,当我在项目的bin/classes目录下使用javah命令生成头文件时,出现了“错误: 无法访问android.app.Activity 找不到android.app.Activity ...

  7. php中soap的使用实例以及生成WSDL文件,提供自动生成WSDL文件的类库——SoapDiscovery.class.php类

    1. web service普及: Webservice soap wsdl区别之个人见解 Web Service实现业务诉求:  Web Service是真正“办事”的那个,提供一种办事接口的统称. ...

  8. 通过MyEclipse生成Hibernate类文件和hbm.xml文件,或者annotation文件

    1.   前言 很多人都在使用myEclipse,很多公司也都使用hibernate框架,老版本的hibernate中,由于没有annotation,我们需要写两个文件来维护表与对象的关系,写一个类, ...

  9. T4 模板自动生成带注释的实体类文件

    T4 模板自动生成带注释的实体类文件 - 只需要一个 SqlSugar.dll 生成实体就是这么简单,只要建一个T4文件和 文件夹里面放一个DLL. 使用T4模板教程 步骤1 创建T4模板 如果你没有 ...

随机推荐

  1. spring 配置定时任务Scheduled

    一:在spring配置的xml文件添加3条命名空间 xmlns:task="http://www.springframework.org/schema/task" xsi:sche ...

  2. Caffe的loss layer(转)

    英文可查:地址 1.SoftmaxWithLoss 对一对多的分类任务计算多项逻辑斯蒂损失,并通过softmax传递预测值,来获得各类的概率分布.该层可以分解为SoftmaxLayer+Multino ...

  3. nodejs学习:net模块

    官方API文档地址:https://nodejs.org/api/net.html 创建一个server.js var net = require('net'); var PORT = 8099; v ...

  4. 39 - 同步-异步-IO多路复用

    目录 1 同步与异步 2 阻塞与非阻塞 3 什么是IO 3.1 内核态用户态 3.2 IO两个阶段 3.3 IO模型 3.3.1 同步阻塞IO 3.3.2 同步非阻塞IO 3.3.3 IO多路复用 3 ...

  5. 【Python项目】爬取新浪微博个人用户信息页

    微博用户信息爬虫 项目链接:https://github.com/RealIvyWong/WeiboCrawler/tree/master/WeiboUserInfoCrawler 1 实现功能 这个 ...

  6. Android浮动窗口的实现

    1.浮动窗口的实现原理 看到上图的那个小Android图标了吧,它不会被其他组建遮挡,也可以响应用户的点击和拖动事件,它的显示和消失由WindowManager直接管理,它就是Android浮动窗口. ...

  7. 01 Go 1.1 Release Notes

    Go 1.1 Release Notes Introduction to Go 1.1 Changes to the language Integer division by zero Surroga ...

  8. Python模块:Random(未完待续)

    本文基于Python 3.6.5的官文random编写. random模块简介 random为各种数学分布算法(distributions)实现了伪随机数生成器. 对于整数,是从一个范围中均匀选择(u ...

  9. Python subprocess- call、check_call、check_output

    简介 subprocess模块用来创建新的进程,连接到其stdin.stdout.stderr管道并获取它们的返回码.subprocess模块的出现是为了替代如下旧模块及函数:os.system.os ...

  10. SQLAlchemy-对象关系教程ORM-一对多(外键),一对一,多对多

    一:一对多 表示一对多的关系时,在子表类中通过 foreign key (外键)引用父表类,然后,在父表类中通过 relationship() 方法来引用子表的类. 在一对多的关系中建立双向的关系,这 ...