当前位置: 首页 > 软件库 > 开发工具 > .NET开发工具 >

AutoCode_vs2010

C#代码生成器
授权协议 非开源
开发语言 C#
所属分类 开发工具、 .NET开发工具
软件类型 开源软件
地区 国产
投 递 者 凤高澹
操作系统 Windows
开源组织
适用人群 未知
 软件概览

AutoCode_vs2010 是 C# 代码生成器

1.代码生成灵活,根据用户所编辑的模板生成代码。

using System;
using System.Collections.Generic;
using System.Text;
using System.IO;
using ToolFunction;
using System.Data;
using CSScriptLibrary;
using Microsoft.CSharp;
using System.Reflection;
using System.Windows.Forms;


namespace AUTOCODE
{
    ////// 测试类
    ///public class @GetClassName(SourceTable)
    {

        @InitProperty(SourceTable)
        
    }
}

	#START@GetCamelCaseName
 	public static string GetCamelCaseName(string value)
        {
            return value.ToLower();
        }
	#END
	
	#START@ConvertFirstCharToUpper
        public static string ConvertFirstCharToUpper(string value)
        {
            return value.Substring(0, 1).ToUpper() + value.Substring(1);
        }
	#END

	#START@InitProperty
	///<summary>/// 生成属性代码
        ///</summary>///<param name="p_dtSource">数据源</param>///<returns>字符串</returns>public static string InitProperty(DataTable p_dtSource)
        {
            string _strLine = "";
            foreach (DataColumn item in p_dtSource.Columns)
            {
                _strLine += "\n private " + GetCSharpVariableType(item) + " " + item.ColumnName.ToLower() + ";";
                _strLine += "\n" + "public " + GetCSharpVariableType(item) + " " + GetPropertyName(item.ColumnName);
                _strLine += "\n" + "{ ";
                _strLine += "\n" + "get { return " + item.ColumnName.ToLower() + ";}";
                _strLine += "\n" + "set {" + item.ColumnName.ToLower() + "= value;}";
                _strLine += "\n" + "}";
            }
            return _strLine;
        }
	#END
	#START@GetClassName
        ///<summary>/// 根据表生成类的名字
        ///</summary>///<param name="p_dtTable">表</param>///<returns></returns>public static  string @GetClassName(DataTable p_dtTable)
        {
            if (p_dtTable == null)
            {
                return null;
            }
            string _strTemp =  p_dtTable.TableName.Substring(0, 1).ToUpper() + p_dtTable.TableName.Substring(1).ToLower();
            return _strTemp;
        }
	#END

	#START@GetPropertyName
        ///<summary>/// 根据表名生成类
        ///</summary>///<param name="p_strName"></param>///<returns></returns>public static  string GetPropertyName(string p_strName)
        {

            if (p_strName == null)
            {
                return null;
            }
            if (p_strName.Length == 1)
            {
                return p_strName.ToLower();
            }
            return p_strName.Substring(0, 1).ToUpper() + p_strName.Substring(1).ToLower();
        }
	#END

	#START@GetLowerCaseName
        public static  string GetLowerCaseName(string value)
        {
            return value.ToLower();
        }
	#END

	#START@GetCSharpVariableType
	///<summary>/// 根据表的列转化代码中的数据类型
        ///</summary>///<param name="p_dcColumn">表列</param>///<returns></returns>public static  string GetCSharpVariableType(DataColumn p_dcColumn)
        {
            if (p_dcColumn.ColumnName.EndsWith("TypeCode")) return p_dcColumn.ColumnName;

            switch (p_dcColumn.DataType.Name.ToString())
            {
                case "AnsiString": return "string";
                case "AnsiStringFixedLength": return "string";
                case "Binary": return "byte[]";
                case "Boolean": return "bool";
                case "Byte": return "byte";
                case "Currency": return "decimal";
                case "Date": return "DateTime";
                case "DateTime": return "DateTime";
                case "Decimal": return "decimal";
                case "Double": return "double";
                case "Guid": return "Guid";
                case "Int16": return "short";
                case "Int32": return "int";
                case "Int64": return "long";
                case "Object": return "object";
                case "SByte": return "sbyte";
                case "Single": return "float";
                case "String": return "string";
                case "StringFixedLength": return "string";
                case "Time": return "TimeSpan";
                case "UInt16": return "ushort";
                case "UInt32": return "uint";
                case "UInt64": return "ulong";
                case "VarNumeric": return "decimal";
                default:
                    {
                        return "__UNKNOWN__";
                    }
            }
        }
	#END


using System;
using System.Collections.Generic;
using System.Text;
using System.IO;
using ToolFunction;
using System.Data;
using CSScriptLibrary;
using Microsoft.CSharp;
using System.Reflection;
using System.Windows.Forms;


namespace AUTOCODE
{
    ////// 测试类
    ///public class @GetClassName(SourceTable)
    {

        @InitProperty(SourceTable)
        
    }
}

	#START@GetCamelCaseName
 	public static string GetCamelCaseName(string value)
        {
            return value.ToLower();
        }
	#END
	
	#START@ConvertFirstCharToUpper
        public static string ConvertFirstCharToUpper(string value)
        {
            return value.Substring(0, 1).ToUpper() + value.Substring(1);
        }
	#END

	#START@InitProperty
	///<summary>/// 生成属性代码
        ///</summary>///<param name="p_dtSource">数据源</param>///<returns>字符串</returns>public static string InitProperty(DataTable p_dtSource)
        {
            string _strLine = "";
            foreach (DataColumn item in p_dtSource.Columns)
            {
                _strLine += "\n private " + GetCSharpVariableType(item) + " " + item.ColumnName.ToLower() + ";";
                _strLine += "\n" + "public " + GetCSharpVariableType(item) + " " + GetPropertyName(item.ColumnName);
                _strLine += "\n" + "{ ";
                _strLine += "\n" + "get { return " + item.ColumnName.ToLower() + ";}";
                _strLine += "\n" + "set {" + item.ColumnName.ToLower() + "= value;}";
                _strLine += "\n" + "}";
            }
            return _strLine;
        }
	#END
	#START@GetClassName
        ///<summary>/// 根据表生成类的名字
        ///</summary>///<param name="p_dtTable">表</param>///<returns></returns>public static  string @GetClassName(DataTable p_dtTable)
        {
            if (p_dtTable == null)
            {
                return null;
            }
            string _strTemp =  p_dtTable.TableName.Substring(0, 1).ToUpper() + p_dtTable.TableName.Substring(1).ToLower();
            return _strTemp;
        }
	#END

	#START@GetPropertyName
        ///<summary>/// 根据表名生成类
        ///</summary>///<param name="p_strName"></param>///<returns></returns>public static  string GetPropertyName(string p_strName)
        {

            if (p_strName == null)
            {
                return null;
            }
            if (p_strName.Length == 1)
            {
                return p_strName.ToLower();
            }
            return p_strName.Substring(0, 1).ToUpper() + p_strName.Substring(1).ToLower();
        }
	#END

	#START@GetLowerCaseName
        public static  string GetLowerCaseName(string value)
        {
            return value.ToLower();
        }
	#END

	#START@GetCSharpVariableType
	///<summary>/// 根据表的列转化代码中的数据类型
        ///</summary>///<param name="p_dcColumn">表列</param>///<returns></returns>public static  string GetCSharpVariableType(DataColumn p_dcColumn)
        {
            if (p_dcColumn.ColumnName.EndsWith("TypeCode")) return p_dcColumn.ColumnName;

            switch (p_dcColumn.DataType.Name.ToString())
            {
                case "AnsiString": return "string";
                case "AnsiStringFixedLength": return "string";
                case "Binary": return "byte[]";
                case "Boolean": return "bool";
                case "Byte": return "byte";
                case "Currency": return "decimal";
                case "Date": return "DateTime";
                case "DateTime": return "DateTime";
                case "Decimal": return "decimal";
                case "Double": return "double";
                case "Guid": return "Guid";
                case "Int16": return "short";
                case "Int32": return "int";
                case "Int64": return "long";
                case "Object": return "object";
                case "SByte": return "sbyte";
                case "Single": return "float";
                case "String": return "string";
                case "StringFixedLength": return "string";
                case "Time": return "TimeSpan";
                case "UInt16": return "ushort";
                case "UInt32": return "uint";
                case "UInt64": return "ulong";
                case "VarNumeric": return "decimal";
                default:
                    {
                        return "__UNKNOWN__";
                    }
            }
        }
	#END



2.提供模板文件管理模块。

3.提供基础配置模块,方便数据库连接,导出目录设置。

4.模板包含属性说明区,函数注册区,静态文本区,动态函数区。规范严谨,易于书写编辑。

5.通过动态编译实现了模板中可添加c#函数,对数据源进行动态操作。

6.多种文件格式导出(只有想生成的文件与数据表有紧密联系,均可根据动态函数区的代码进行代码生成)

未完成功能

支持SqlServer、mysql.



 相关资料
  • 我正在根据参考指南学习使用Map结构。日食验证是 面向Web开发人员的Eclipse Java EE IDE。版本:开普勒服务版本2 pom。xml如下所示,与参考指南相同 它表示在构建项目时将生成实现代码。但是,它似乎不会在目标/生成的源文件夹下生成

  • Jboot 内置了一个简易的代码生成器,可以用来生成model层和Service层的基础代码,在生成代码之前,请先配置jboot.properties关于数据库相关的配置信息,Jboot 代码生成器会通过该配置去链接数据库。 jboot.datasource.type=mysql jboot.datasource.url=jdbc:mysql://127.0.0.1:3306/jbootdemo

  • 遵照此规范,在实际操作中,有许多重复。接下来推荐一款专为本规范量身定做的代码生成器 Laravel 5.x Scaffold Generator。 本扩展支持 5.1 ~ 5.5 版本的 Laravel。 只需要一个命令: 即可生成: $ php artisan make:scaffold Projects --schema="name:string:index,description:text:

  • Sergen 有一些额外的配置选项,你可以通过解决方案目录下的配置文件(Serenity.CodeGenerator.config)设置。 这是所有的配置选项: public class GeneratorConfig { public List<Connection> Connections { get; set; } public string KDiff3Path { get

  • 我使用jOOQ程序代码生成数据库,但现在我遇到了一些问题。在数据库中,我有表A和表B。第一次都生成了pojo、dao、接口等。经过一段时间的开发,我发现表A需要添加一些字段或修改一些字段,所以我不得不再次编码,然后jOOQ代码生成器将覆盖现有的代码,这让我很难过。当我在排除表的情况下使用“排除A”时,发现只生成了表A的数据,表B将被删除。我不知道如何处理这个问题。我的代码生成器如下:

  • 根据数据库表生成对应的增,删,改,查功能,和 js 验证功能! 目前支持的是oracle 数据库,写自行修改 项目本身可以做为PHP新手的入门程序!

  • 大多数Blockly应用程序需要将块转换为代码以执行。本页描述如何将代码生成器添加到自定义块。 首先,转到generators/目录并选择与您要生成的语言(JavaScript,Python,PHP,Lua,Dart等)相对应的子目录。假设您的代码块不适合现有类别,请创建一个新的JavaScript文件。这个新的JavaScript文件需要包含在<script ...>编辑器的HTML文件中的标记

  • 注: 内容来自官网资料 Java Generated Code 这个页面准确描述 protocol buffer 编译器为任何给定协议定义生成的java代码。proto2和proto3生成的代码之间的任何不同都将被高亮 - 注意在这份文档中描述的是这些生成代码的不同,而不是基本的消息类/接口,后者在两个版本中是相同的。在阅读这份文档之前你应该先阅读 proto2语言指南 和/或 proto3语言指