C#代码生成器 AutoCode_vs2010

非开源
C#
Windows
2015-04-02
登录-注册

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.



加载中

评论(0)

暂无评论

暂无资讯

暂无问答

axis2 webservice服务端接口配置步骤

axis2 webservice服务端开发

2016/03/24 10:56
168
1
项目管理工具总结

项目代码管理工具 github gitlab(https://about.gitlab.com/downloads/) gitlab centos 上安装gitlab(https://github.com/gitlabhq/gitlab-recipes/tree/master/install/centos) 项目进度管...

2016/05/11 19:57
293
3
4.自动生成代码使用说明

本框架是一个基础后台开发框架,基于springmvc+spring+hibernate搭建,前端采用angular js+sea js +bootstrap展现,基于shiro的权限管理和登陆控制。基础框架中包含了用户管理、权限管理等基...

2016/07/20 09:37
168
0
molicode使用示例教程附动态图

molicode使用示例教程附动态图 项目配置 项目配置包括数据库连接配置,工程目录设置(模板地址),业务代码配置等; 项目配置->数据库设置 (如果需要数据库模型生成) 项目配置->工程目录配...

07/23 17:52
62
1
打印自身的程序

分享一个网站,里面全是打印自身函数的例子

2016/12/26 22:23
23
0
QT下载地址

上Qt官网http://www.qt.io/download/想下载Qt,速度很慢,在这里记录下在Qt官网看到的镜像下载地址: 1. 所有Qt版本下载地址: http://download.qt.io/archive/qt/ 2. 所有Qt Creator下载地址...

2018/07/08 20:13
113
1
调试利器--VS2010(有图有真相)

本文旨在与园友分享VS2010的强大debug功能,此所谓“工欲善其事,比先利其器”! 一、通过VS2010可以将断点保存成本地文件(xml格式) 假设当代码中有CRUD(增、删、改、查)功能时,我们deb...

2012/03/09 12:53
113
0

没有更多内容

加载失败,请刷新页面

返回顶部
顶部