Python生成Thinkphp6代码工具类

简介: Python生成Thinkphp6代码工具类

Python生成Thinkphp6代码

# pip install pymysql
# pip install os
import pymysql
import os
# 数据库配置
db_config = {
    'host': 'IP',
    'port': 3306,
    'user': 'root',
    'password': 'PWD',
    'database': 'DBNAME',
    'charset': 'utf8mb4'
}
# 连接到数据库
connection = pymysql.connect(**db_config)
# 获取表字段
def get_table_structure(table_name):
    with connection.cursor() as cursor:
        cursor.execute(f"DESCRIBE {table_name}")
        return cursor.fetchall()
# 驼峰命名
def convert_to_camel_case(snake_str):
    components = snake_str.split('_')
    return ''.join(x.capitalize() for x in components)
# 生成model代码
def generate_model_code(table_name, columns, package_name):
    class_name = convert_to_camel_case(table_name) + "Model"
    fields = ',\n    '.join([f"'{column[0]}'" for column in columns])
    
    model_code = f"""<?php
    namespace app\\model\\{package_name};
    use think\\Model;
    class {class_name} extends Model
    {{
        protected $table = '{table_name}';
        protected $fields = [
            {fields}
        ];
    }}
    """
    return model_code
# 生成Controller代码
def generate_controller_code(table_name, columns, package_name):
    class_name = convert_to_camel_case(table_name) + "Controller"
    model_class_name = convert_to_camel_case(table_name) + "Model"
    
    controller_code = f"""<?php
    namespace app\\controller\\{package_name};
    use app\\model\\{package_name}\\{model_class_name};
    use think\\facade\\Request;
    use think\\exception\\ValidateException;
    use think\\response\\Json;
    class {class_name}
    {{
        /**
        * 获取列表(分页)
        * @return Json
        */
        public function listsAjax()
        {{
            $page = Request::get('page', 1);
            $limit = Request::get('limit', 20);
            $name = Request::get('name'); // 要查询的字段
            $whereMap = [];
            if (!empty($name)) $whereMap[] = ['name', 'like', "%{{$name}}%"];
            $model = new {model_class_name}();
            $count = $model->where($whereMap)->count();
            $data = $model->where($whereMap)->limit(($page - 1) * $limit, $limit)->select()->toArray();
            return json([
                'status' => 1,
                'msg' => '',
                'data' => [
                    'page' => $page,
                    'totalPage' => ceil($count / $limit),
                    'limit' => $limit,
                    'totalNum' => $count,
                    'data' => $data
                ]
            ]);
        }}
        /**
        * 保存信息
        * @return Json
        */
        public function saveAjax()
        {{
            $data = Request::post();
            $model = new {model_class_name}();
            try {{
                if (!empty($data['id'])) {{
                    // 更新,不允许修改创建时间
                    unset($data['create_time']);
                    $data['modified_time'] = date('Y-m-d H:i:s');
                    $result = $model->strict(false)->where('id', $data['id'])->save($data);
                }} else {{
                    unset($data['id']);  // 删除空字符串等情况下的id属性
                    // 新增表数据
                    $result = $model->strict(false)->save($data);
                }}
                if (!empty($result)) {{
                    return json([
                        'status' => 1,'msg' => '操作成功','data' => []
                    ]);
                }} else {{
                    return json([
                        'status' => 0,'msg' => '操作失败,请重试','data' => []
                    ]);
                }}
            }} catch (ValidateException $e) {{
                return json([
                    'status' => 0,'msg' => '验证失败: ' . $e->getMessage(),'data' => []
                ]);
            }} catch (\\Exception $e) {{
                return json([
                    'status' => 0,'msg' => '异常: ' . $e->getMessage(),'data' => []
                ]);
            }}
        }}
        /**
        * 删除信息
        * @return Json
        */
        public function removeAjax()
        {{
            $id = Request::post('id');
            if (empty($id)) {{
                return json([
                    'status' => 0,
                    'msg' => '参数错误',
                    'data' => []
                ]);
            }}
            $model = new {model_class_name}();
            $res = $model->where('id', $id)->delete();
            if (!empty($res)) {{
                return json([
                    'status' => 1,'msg' => '删除成功','data' => []
                ]);
            }} else {{
                return json([
                    'status' => 0,'msg' => '删除失败','data' => []
                ]);
            }}
        }}
        /**
        * 更新flag标志位
        * @return Json
        */
        public function updateFlagAjax()
        {{
            $id = Request::post('id');
            $flag = Request::post('flag');
            if (empty($id) || !isset($flag)) {{
                return json([
                    'status' => 0,'msg' => '参数错误','data' => []
                ]);
            }}
            $model = new {model_class_name}();
            $result = $model->where('id', $id)->update(['flag' => $flag,'modified_time'=>date('Y-m-d H:i:s')]);
            if (!empty($result)) {{
                return json([
                    'status' => 1,'msg' => '更新成功','data' => []
                ]);
            }} else {{
                return json([
                    'status' => 0,'msg' => '更新失败','data' => []
                ]);
            }}
        }}
    }}
    """
    return controller_code
# 生成route代码
def generate_route_code(table_name, package_name):
    controller_class_name = convert_to_camel_case(table_name) + "Controller"
    route_code = f"""<?php
    use think\\facade\\Route;
    Route::resource('{convert_to_camel_case(table_name)}', '{package_name}\\controller\\{controller_class_name}');
    """
    return route_code
# 生成文件即文件代码
def generate_code_for_table(table_name, package_name):
    columns = get_table_structure(table_name)
    model_class_name = convert_to_camel_case(table_name) + "Model"
    controller_class_name = convert_to_camel_case(table_name) + "Controller"
    
    model_code = generate_model_code(table_name, columns, package_name)
    controller_code = generate_controller_code(table_name, columns, package_name)
    route_code = generate_route_code(table_name, package_name)
    package_path = package_name.replace("\\", "/")
    model_dir = os.path.join(package_path, 'model')
    controller_dir = os.path.join(package_path, 'controller')
    route_dir = os.path.join(package_path, 'route')
    # 创建目录
    os.makedirs(model_dir, exist_ok=True)
    os.makedirs(controller_dir, exist_ok=True)
    os.makedirs(route_dir, exist_ok=True)
    
    with open(f"{model_dir}/{model_class_name}.php", "w") as model_file:
        model_file.write(model_code)
    
    with open(f"{controller_dir}/{controller_class_name}.php", "w") as controller_file:
        controller_file.write(controller_code)
    
    with open(f"{route_dir}/{convert_to_camel_case(table_name)}Route.php", "w") as route_file:
        route_file.write(route_code)
    print(f"{table_name}代码生成完毕")
def main(tables, package_name):
    table_list = tables.split(',')
    for table in table_list:
        generate_code_for_table(table.strip(), package_name)
# 执行main方法
main('tbl_name', 'packageName')
相关文章
|
30天前
|
开发框架 数据建模 中间件
Python中的装饰器:简化代码,增强功能
在Python的世界里,装饰器是那些静悄悄的幕后英雄。它们不张扬,却能默默地为函数或类增添强大的功能。本文将带你了解装饰器的魅力所在,从基础概念到实际应用,我们一步步揭开装饰器的神秘面纱。准备好了吗?让我们开始这段简洁而富有启发性的旅程吧!
35 6
|
2月前
|
存储 缓存 测试技术
Python中的装饰器:功能增强与代码复用的利器
在Python编程中,装饰器是一种强大而灵活的工具,它允许开发者以简洁优雅的方式增强函数或方法的功能。本文将深入探讨装饰器的定义、工作原理、应用场景以及如何自定义装饰器。通过实例演示,我们将展示装饰器如何在不修改原有代码的基础上添加新的行为,从而提高代码的可读性、可维护性和复用性。此外,我们还将讨论装饰器在实际应用中的一些最佳实践和潜在陷阱。
|
3天前
|
Python
课程设计项目之基于Python实现围棋游戏代码
游戏进去默认为九路玩法,当然也可以选择十三路或是十九路玩法 使用pycharam打开项目,pip安装模块并引用,然后运行即可, 代码每行都有详细的注释,可以做课程设计或者毕业设计项目参考
47 33
|
4天前
|
JavaScript API C#
【Azure Developer】Python代码调用Graph API将外部用户添加到组,结果无效,也无错误信息
根据Graph API文档,在单个请求中将多个成员添加到组时,Python代码示例中的`members@odata.bind`被错误写为`members@odata_bind`,导致用户未成功添加。
30 10
|
2月前
|
人工智能 数据挖掘 Python
Python编程基础:从零开始的代码旅程
【10月更文挑战第41天】在这篇文章中,我们将一起探索Python编程的世界。无论你是编程新手还是希望复习基础知识,本文都将是你的理想之选。我们将从最基础的语法讲起,逐步深入到更复杂的主题。文章将通过实例和练习,让你在实践中学习和理解Python编程。让我们一起开启这段代码之旅吧!
|
23天前
|
数据可视化 Python
以下是一些常用的图表类型及其Python代码示例,使用Matplotlib和Seaborn库。
通过这些思维导图和分析说明表,您可以更直观地理解和选择适合的数据可视化图表类型,帮助更有效地展示和分析数据。
64 8
|
1月前
|
API Python
【Azure Developer】分享一段Python代码调用Graph API创建用户的示例
分享一段Python代码调用Graph API创建用户的示例
51 11
|
1月前
|
测试技术 Python
探索Python中的装饰器:简化代码,增强功能
在Python的世界中,装饰器是那些能够为我们的代码增添魔力的小精灵。它们不仅让代码看起来更加优雅,还能在不改变原有函数定义的情况下,增加额外的功能。本文将通过生动的例子和易于理解的语言,带你领略装饰器的奥秘,从基础概念到实际应用,一起开启Python装饰器的奇妙旅程。
40 11
|
28天前
|
Python
探索Python中的装饰器:简化代码,增强功能
在Python的世界里,装饰器就像是给函数穿上了一件神奇的外套,让它们拥有了超能力。本文将通过浅显易懂的语言和生动的比喻,带你了解装饰器的基本概念、使用方法以及它们如何让你的代码变得更加简洁高效。让我们一起揭开装饰器的神秘面纱,看看它是如何在不改变函数核心逻辑的情况下,为函数增添新功能的吧!
|
29天前
|
程序员 测试技术 数据安全/隐私保护
深入理解Python装饰器:提升代码重用与可读性
本文旨在为中高级Python开发者提供一份关于装饰器的深度解析。通过探讨装饰器的基本原理、类型以及在实际项目中的应用案例,帮助读者更好地理解并运用这一强大的语言特性。不同于常规摘要,本文将以一个实际的软件开发场景引入,逐步揭示装饰器如何优化代码结构,提高开发效率和代码质量。
48 6