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、端口扫描原…...

接口测试中缓存处理策略
在接口测试中,缓存处理策略是一个关键环节,直接影响测试结果的准确性和可靠性。合理的缓存处理策略能够确保测试环境的一致性,避免因缓存数据导致的测试偏差。以下是接口测试中常见的缓存处理策略及其详细说明: 一、缓存处理的核…...

业务系统对接大模型的基础方案:架构设计与关键步骤
业务系统对接大模型:架构设计与关键步骤 在当今数字化转型的浪潮中,大语言模型(LLM)已成为企业提升业务效率和创新能力的关键技术之一。将大模型集成到业务系统中,不仅可以优化用户体验,还能为业务决策提供…...

【网络安全产品大调研系列】2. 体验漏洞扫描
前言 2023 年漏洞扫描服务市场规模预计为 3.06(十亿美元)。漏洞扫描服务市场行业预计将从 2024 年的 3.48(十亿美元)增长到 2032 年的 9.54(十亿美元)。预测期内漏洞扫描服务市场 CAGR(增长率&…...
Caliper 配置文件解析:config.yaml
Caliper 是一个区块链性能基准测试工具,用于评估不同区块链平台的性能。下面我将详细解释你提供的 fisco-bcos.json 文件结构,并说明它与 config.yaml 文件的关系。 fisco-bcos.json 文件解析 这个文件是针对 FISCO-BCOS 区块链网络的 Caliper 配置文件,主要包含以下几个部…...
OpenLayers 分屏对比(地图联动)
注:当前使用的是 ol 5.3.0 版本,天地图使用的key请到天地图官网申请,并替换为自己的key 地图分屏对比在WebGIS开发中是很常见的功能,和卷帘图层不一样的是,分屏对比是在各个地图中添加相同或者不同的图层进行对比查看。…...
laravel8+vue3.0+element-plus搭建方法
创建 laravel8 项目 composer create-project --prefer-dist laravel/laravel laravel8 8.* 安装 laravel/ui composer require laravel/ui 修改 package.json 文件 "devDependencies": {"vue/compiler-sfc": "^3.0.7","axios": …...

SiFli 52把Imagie图片,Font字体资源放在指定位置,编译成指定img.bin和font.bin的问题
分区配置 (ptab.json) img 属性介绍: img 属性指定分区存放的 image 名称,指定的 image 名称必须是当前工程生成的 binary 。 如果 binary 有多个文件,则以 proj_name:binary_name 格式指定文件名, proj_name 为工程 名&…...

RSS 2025|从说明书学习复杂机器人操作任务:NUS邵林团队提出全新机器人装配技能学习框架Manual2Skill
视觉语言模型(Vision-Language Models, VLMs),为真实环境中的机器人操作任务提供了极具潜力的解决方案。 尽管 VLMs 取得了显著进展,机器人仍难以胜任复杂的长时程任务(如家具装配),主要受限于人…...

三分算法与DeepSeek辅助证明是单峰函数
前置 单峰函数有唯一的最大值,最大值左侧的数值严格单调递增,最大值右侧的数值严格单调递减。 单谷函数有唯一的最小值,最小值左侧的数值严格单调递减,最小值右侧的数值严格单调递增。 三分的本质 三分和二分一样都是通过不断缩…...
LRU 缓存机制详解与实现(Java版) + 力扣解决
📌 LRU 缓存机制详解与实现(Java版) 一、📖 问题背景 在日常开发中,我们经常会使用 缓存(Cache) 来提升性能。但由于内存有限,缓存不可能无限增长,于是需要策略决定&am…...