thinkphp6.1~8.0 快速创建CRUD
GIT 源码 TINKPHP
快速创建模型CRUD源码
import os
import tkinter as tk
from tkinter import messagebox#转小写
def toLowerCase(str):""":type str: str:rtype: str"""return "".join(chr(ord(c) + 32) if 65 <= ord(c) <= 90 else c for c in str)
#转表格式
def castTable(table):input_str = tableoutput_str = ""for char in input_str:if char.isupper():output_str += "_" + char.lower()else:output_str += charoutput_str = output_str.lstrip("_")return output_str
#转换驼峰模式
def castHump(table):input_str = tableoutput_str = "".join(word.capitalize() for word in input_str.split("_"))return output_str
#模型修改
def createModel(name):current_dir = os.getcwd()model=current_dir+"\\"+"app\model\\"+name+"Model.php"lines=[]f = open(model,"r",encoding="utf-8")n=0for line in f.readlines():lines.append(line)if n==12:table=" protected $name = '"+castTable(name)+"';"+"\n"lines.append(table)n+=1s=''.join(lines)f=open(model,'w+',encoding='utf-8')f.write(s)f.close()
#控制器修改
def createController(name):current_dir = os.getcwd()controller=current_dir+"\\"+"app\controller\\"+name+".php"lines=[]f = open(controller,"r",encoding="utf-8")n=0controllLine=0for line in f.readlines():lines.append(line)if n==5:table="use app\service\\"+name+"Service;"+"\n"lines.append(table)n+=1if line.find("//")>0:controllLine+=1if line.find("//")>0 and controllLine==1:#index方法index=" return "+name+"Service::index($request->param());"+"\n"lines.append(index)if line.find("//")>0 and controllLine==2:#create方法create=" return "+name+"Service::create($request->param());"+"\n"lines.append(create)if line.find("//")>0 and controllLine==5:#edit方法edit=" return "+name+"Service::update($request->param());"+"\n"lines.append(edit) if line.find("//")>0 and controllLine==7:#delete方法delete=" return "+name+"Service::delete($id);"+"\n"lines.append(delete) s=''.join(lines)s=s.replace("index()", "index(Request $request)")s=s.replace("create()", "create(Request $request)")s=s.replace("edit($id)", "edit(Request $request)")f=open(controller,'w+',encoding='utf-8')f.write(s)f.close()
#服务修改
def createService(name):current_dir = os.getcwd()service=current_dir+"\\"+"app\service\\"+name+"Service.php"lines=[]f = open(service,"r",encoding="utf-8")n=0serviceLine=0end=0for line in f.readlines():lines.append(line)if n==3:table="use app\model\\"+name+"Model;"+"\n"lines.append(table)baseService="use app\BaseService;"+"\n"lines.append(baseService)n+=1if line.find("//")>0:serviceLine+=1if end==1:lines.append(" public static function index($data){"+"\n")lines.append(" return self::baseList(new "+name+"Model(),$data);"+"\n")lines.append(" }"+"\n")lines.append(" public static function create($data){"+"\n")lines.append(" return self::baseCreate(new "+name+"Model(),$data);"+"\n")lines.append(" }"+"\n")lines.append(" public static function update($data){"+"\n")lines.append(" return self::baseUpdate(new "+name+"Model(),$data);"+"\n")lines.append(" }"+"\n")lines.append(" public static function delete($data){"+"\n")lines.append(" return self::baseDelete(new "+name+"Model(),$data);"+"\n")lines.append(" }"+"\n")end=2if line.find("//")>0 and serviceLine==2:end=1s=''.join(lines)s=s.replace("\\think\\Service", "BaseService")f=open(service,'w+',encoding='utf-8')f.write(s)f.close()#创建路由
def createRoute(name):current_dir = os.getcwd()route=current_dir+"\\"+"route\\app.php"lines=[]f = open(route,"r",encoding="utf-8") name=name[0].lower() + name[1:]for line in f.readlines():if line.find("结尾符")>0:lines.append("Route::post('"+name+"/list', '"+name+"/index');"+"\n")lines.append("Route::post('"+name+"/create', '"+name+"/create');"+"\n")lines.append("Route::post('"+name+"/edit', '"+name+"/edit');"+"\n")lines.append("Route::post('"+name+"/delete', '"+name+"/delete');"+"\n")lines.append("//结尾符用作快速创建路由"+"\n")else:lines.append(line)s=''.join(lines)f=open(route,'w+',encoding='utf-8')f.write(s)f.close()
def button_click():input_text = entry.get()#转驼峰input_text =castHump(input_text)current_dir = os.getcwd()#进入根目录os.system("cd "+ current_dir)#表名#table="Test"#执行命令commandController="php think make:controller app\controller\\"+input_textstatus=os.system(commandController)commandModel="php think make:model app\model\\"+input_text+"Model"statusModel=os.system(commandModel)commandService="php think make:service app\service\\"+input_text+"Service"statusService=os.system(commandService)createModel(input_text)createController(input_text)createService(input_text)#路由接口createRoute(input_text)messagebox.showinfo("提示", "执行完成")
# 创建主窗口
root = tk.Tk()
root.geometry("423x131")
root.title("快速创建模型")# 创建输入框
entry = tk.Entry(root)
entry.pack()# 创建按钮
button = tk.Button(root, text="点击", command=button_click)
button.pack()# 运行主循环
root.mainloop()
相关文章:
thinkphp6.1~8.0 快速创建CRUD
GIT 源码 TINKPHP 快速创建模型CRUD源码 import os import tkinter as tk from tkinter import messagebox#转小写 def toLowerCase(str):""":type str: str:rtype: str"""return "".join(chr(ord(c) 32) if 65 < ord(c) < 90…...
MySQL的常用函数
MySQL函数 聚合函数时间函数字符集函数数学函数其他函数 聚合函数 函数名说明COUNT()统计个数SUM()总和,不是数字没有意义AVG()求平均值,不是数字没有意义MAX()求最大值,不是数字没有意义MIN()求最小值,不是数字没有意义 group …...
Android Gradle 开发与应用 (五) : 基于Gradle 8.2,创建Gradle插件
1. 前言 本文介绍在Android中,如何基于Gradle 8.2,创建Gradle插件。 1.1 本文环境 Android Studio 版本 : Android Studio Hedgehog | 2023.1.1Gralde版本 : gradle 8.2 使用 Android Gradle 插件升级助理 Android Gradle 插件版本说明 1.2 为什么要写…...
中文在职博士|中国社科院-新加坡社科大学(公立大学)工商管理博士
中文在职博士|中国社科院-新加坡社科大学(公立大学)工商管理博士 中国社科大-新加坡社科大学合作举办全球战略领导力博士项目 【条件】:硕士学位+三年管理经验 【证书】:颁发新加坡社科大学博士学位证书 【招生】&…...
前端性能优化终极指南
前端性能优化一直是很多同学非常关注的问题,在日常的面试中也是经常会被用到的点。今天就来了解一下前端性能优化方案。 一:页面渲染相关 01:减少页面重绘和回流 回流(reflow):是指由于DOM结构或样式发生…...
基于Logstash由SQLServer向Elasticsearch同步数据: logstash配置文件
文章目录 I Logstash1.1 Logstash 安装1.2 logstash配置文件参数含义1.3 启动LogstashII 增量数据同步方案2.1 思路2.2 使用LastModifyTime来追踪DB的变更数据2.3 将最大ID 设置为查询条件,获取增量数据2.4 把时间戳设置为记录产生的时间III 单表同步IV 多表同步V 使用 Logsta…...
sqllab第八关通关笔记
知识点: 这里感觉是一个单纯的单引号绕过bp爆破配置的条件和第七关一样 首先判断注入类型 构造id1/0 回显成功 构造id1 错误回显,感觉又是一个单引号绕过 构造id1 正常回显了,说明不错,就是一个单引号绕过 构造payload:id1 a…...
unity text 文本符号显示问题与打字机效果的结合
问题1:unity text显示文本时,符号可能显示在某行的开头的位置 问题2:打字机效果没有适配问题1的脚本 解决方法: 问题1:通过遍历text组件每一行数据(第二行开始),如果是符号,就在它之前的字符前…...
Netty架构详解
文章目录 概述整体结构Netty的核心组件逻辑架构BootStrap & ServerBootStrapChannelPipelineFuture、回调和 ChannelHandler选择器、事件和 EventLoopChannelHandler的各种ChannelInitializer类图 Protocol Support 协议支持层Transport Service 传输服务层Core 核心层模块…...
Unity自带的WebSocket使用说明
Unity中的WebSocket是一种用于实时性强、低延迟的双向通信的技术。它可以在客户端和服务器之间建立一个持久的连接,允许双方随时互相发送数据。这种实时性使得WebSocket在游戏中非常有用,特别是对于多人在线游戏和实时竞技游戏。 在Unity中,…...
【Web】浅聊XStream反序列化之SortedSetTreeMap利用链
前文:【Web】浅聊XStream反序列化本源之恶意动态代理注入-CSDN博客 前言 在上一篇文章我们聊到可以用XStream反序列化来进行恶意动态代理的注入,但其有一个很大的限制就是必须要知道目标靶机会调用哪个接口的方法,才能去相应地精心构造对应…...
HTML CSS学习
# html css 日常学习记录---学习途径--渡一教育-袁老师# 元素包含关系 以前:块级元素可以包含行级元素,行级元素不可以包含块级元素,a元素除外 元素的包含关系由元素的内容类别决定。 例如,查看h1元素中是否可以包含p元素 总…...
MySQL的事务隔离是如何实现的?
目录 从一个例子说起 快照读和当前读 事务的启动时机和读视图生成的时刻 MVCC 隐藏字段 Undo Log回滚日志 Read View - 读视图 可重复读(RC)隔离级别下的MVCC 读提交(RR)隔离级别下的MCC 关于MVCC的一些疑问 1.为什么需要 MVCC ?如果没有 MVCC 会怎样&am…...
STM32电源及时钟介绍
一、STM32最小系统 二、电源电路 2.1供电电压VDD,VSS F103VET6 的引角图 在 F103VET6 的引角图中可找到 49\50 角, 74\75 角, 99\100 角, 27\28角,10 \11角一共 5 对的VDD,VSS,也就是给我们芯片…...
使用公式在Excel中指定列值的变化实现自动间隔着色(不是按照固定的行数)
如果你的文件很小,可以手工着色;但如果很大,就要借助公式来着色; 目的是什么,其中之一是:提升可读性。 一起往下看吧!! 如果你想要根据Excel某列中值的变化来间隔着色,…...
蚓链给传统供应链的数字化解决方案会带来什么价值呢?
传统供应链在蚓链数字化的加持下,通过互相融合、结合将为数字经济带来多方面的影响和变革,包括但不限于以下几点: 1. 提高效率和降低成本:数字化可以优化供应链中的各个环节,例如采购、生产、物流和销售等࿰…...
有来团队后台项目-解析8
UnoCss 介绍 UnoCss 官网UnoCss 官网 安装 pnpm add -D unocss引入 vite.config.ts import UnoCSS from unocss/vite // plugins 中引入 UnoCSS({/* options */ }),创建uno.config.ts // uno.config.ts import {defineConfig,presetAttributify,presetIcons,presetTyp…...
vs2022的下载及安装教程(Visual Studio 2022)
vs简介 Visual Studio在团队项目开发中使用非常多且功能强大,支持开发人员编写跨平台的应用程序;Microsoft Visual C 2022正式版(VC2022运行库),具有程序框架自动生成,灵活方便的类管理,强大的代码编写等功能,可提供编…...
BFS(宽度优先搜索)C++(Acwing)
代码: #include <cstring> #include <iostream> #include <algorithm>using namespace std;typedef pair<int, int> PII;const int N 110;int n, m; int g[N][N]; int d[N][N]; PII q[N * N];int bfs() {int hh 0, tt 0;q[0] {0, 0};m…...
信息收集:端口扫描原理,端口扫描分类,端口扫描工具,手动判断操作系统,操作系统识别工具
「作者主页」:士别三日wyx 「作者简介」:CSDN top100、阿里云博客专家、华为云享专家、网络安全领域优质创作者 「专栏简介」:此文章已录入专栏《网络安全自学教程》 端口&系统版本 一、端口扫描1、telnet2、Nmap3、Masscan4、端口扫描原…...
龙虎榜——20250610
上证指数放量收阴线,个股多数下跌,盘中受消息影响大幅波动。 深证指数放量收阴线形成顶分型,指数短线有调整的需求,大概需要一两天。 2025年6月10日龙虎榜行业方向分析 1. 金融科技 代表标的:御银股份、雄帝科技 驱动…...
OpenLayers 可视化之热力图
注:当前使用的是 ol 5.3.0 版本,天地图使用的key请到天地图官网申请,并替换为自己的key 热力图(Heatmap)又叫热点图,是一种通过特殊高亮显示事物密度分布、变化趋势的数据可视化技术。采用颜色的深浅来显示…...
C++_核心编程_多态案例二-制作饮品
#include <iostream> #include <string> using namespace std;/*制作饮品的大致流程为:煮水 - 冲泡 - 倒入杯中 - 加入辅料 利用多态技术实现本案例,提供抽象制作饮品基类,提供子类制作咖啡和茶叶*//*基类*/ class AbstractDr…...
PPT|230页| 制造集团企业供应链端到端的数字化解决方案:从需求到结算的全链路业务闭环构建
制造业采购供应链管理是企业运营的核心环节,供应链协同管理在供应链上下游企业之间建立紧密的合作关系,通过信息共享、资源整合、业务协同等方式,实现供应链的全面管理和优化,提高供应链的效率和透明度,降低供应链的成…...
java 实现excel文件转pdf | 无水印 | 无限制
文章目录 目录 文章目录 前言 1.项目远程仓库配置 2.pom文件引入相关依赖 3.代码破解 二、Excel转PDF 1.代码实现 2.Aspose.License.xml 授权文件 总结 前言 java处理excel转pdf一直没找到什么好用的免费jar包工具,自己手写的难度,恐怕高级程序员花费一年的事件,也…...
为什么需要建设工程项目管理?工程项目管理有哪些亮点功能?
在建筑行业,项目管理的重要性不言而喻。随着工程规模的扩大、技术复杂度的提升,传统的管理模式已经难以满足现代工程的需求。过去,许多企业依赖手工记录、口头沟通和分散的信息管理,导致效率低下、成本失控、风险频发。例如&#…...
【SQL学习笔记1】增删改查+多表连接全解析(内附SQL免费在线练习工具)
可以使用Sqliteviz这个网站免费编写sql语句,它能够让用户直接在浏览器内练习SQL的语法,不需要安装任何软件。 链接如下: sqliteviz 注意: 在转写SQL语法时,关键字之间有一个特定的顺序,这个顺序会影响到…...
论文浅尝 | 基于判别指令微调生成式大语言模型的知识图谱补全方法(ISWC2024)
笔记整理:刘治强,浙江大学硕士生,研究方向为知识图谱表示学习,大语言模型 论文链接:http://arxiv.org/abs/2407.16127 发表会议:ISWC 2024 1. 动机 传统的知识图谱补全(KGC)模型通过…...
【HTML-16】深入理解HTML中的块元素与行内元素
HTML元素根据其显示特性可以分为两大类:块元素(Block-level Elements)和行内元素(Inline Elements)。理解这两者的区别对于构建良好的网页布局至关重要。本文将全面解析这两种元素的特性、区别以及实际应用场景。 1. 块元素(Block-level Elements) 1.1 基本特性 …...
LLM基础1_语言模型如何处理文本
基于GitHub项目:https://github.com/datawhalechina/llms-from-scratch-cn 工具介绍 tiktoken:OpenAI开发的专业"分词器" torch:Facebook开发的强力计算引擎,相当于超级计算器 理解词嵌入:给词语画"…...
