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、端口扫描原…...
从SIM800到BK A7670E:4G Cat.1模块硬件平替转接板设计全解析
1. 项目概述:从2G到4G的硬件平替升级 手头有个老项目,用的还是SIM800这种经典的2G模块,现在网络环境变了,2G退网是大势所趋,信号覆盖越来越差,项目得活下去,升级到4G成了刚需。但问题来了&#…...
Python多智能体建模终极指南:用Mesa轻松构建复杂系统仿真
Python多智能体建模终极指南:用Mesa轻松构建复杂系统仿真 【免费下载链接】mesa Mesa is an open-source Python library for agent-based modeling, ideal for simulating complex systems and exploring emergent behaviors. 项目地址: https://gitcode.com/gh_…...
Armv9-A架构解析:SVE/SME与安全增强技术
1. Armv9-A架构演进与核心特性全景Armv9-A架构代表了Arm公司面向未来十年计算需求的设计哲学,其核心在于三个维度的突破:性能、安全与专用计算。作为长期从事Arm架构开发的工程师,我见证了从Armv7到Armv9的技术跃迁。与固定宽度向量指令的NEO…...
终极指南:如何用ESP32打造专业级蓝牙游戏手柄
终极指南:如何用ESP32打造专业级蓝牙游戏手柄 【免费下载链接】ESP32-BLE-Gamepad Bluetooth LE Gamepad library for the ESP32 项目地址: https://gitcode.com/gh_mirrors/es/ESP32-BLE-Gamepad 你是否曾经想过用ESP32开发板制作一个自定义的游戏控制器&am…...
023、深度可分离卷积:MobileNet背后的计算优化
深度可分离卷积:MobileNet背后的计算优化 一个让我加了两天班的bug 去年调试一块基于Cortex-M7的AI推理引擎,跑MobileNetV1时发现推理速度比理论计算慢了整整一个数量级。当时我盯着逻辑分析仪上的波形,CPU在卷积层卡了将近300ms——这不对劲,理论计算应该只要30ms。 排…...
事故数据四年连降,为何山西煤矿的命还是悬在一根绳上?
说实话,写到山西煤矿这四个字,我心里就咯噔一下。2026年5月22日19时29分,山西长治市沁源县山西通洲集团留神峪煤业有限公司井下发生瓦斯爆炸事故,截至到写稿,事故已造成90人遇难。看的心里堵得慌。我特意去翻了翻这些年…...
为什么你的Windows快捷键突然失效?3分钟找出罪魁祸首
为什么你的Windows快捷键突然失效?3分钟找出罪魁祸首 【免费下载链接】hotkey-detective A small program for investigating stolen key combinations under Windows 7 and later. 项目地址: https://gitcode.com/gh_mirrors/ho/hotkey-detective 你是否经历…...
Redis Bitmap的隐藏用法:从“优惠券防超领”到“大数据去重”的实战避坑指南
Redis Bitmap的隐藏用法:从“优惠券防超领”到“大数据去重”的实战避坑指南 在数据密集型的现代应用中,如何高效处理海量数据的唯一性校验和状态标记,一直是开发者面临的挑战。Redis的Bitmap数据结构以其极低的内存消耗和O(1)时间复杂度的位…...
终极指南:使用SMUDebugTool深度掌控AMD Ryzen系统底层参数
终极指南:使用SMUDebugTool深度掌控AMD Ryzen系统底层参数 【免费下载链接】SMUDebugTool A dedicated tool to help write/read various parameters of Ryzen-based systems, such as manual overclock, SMU, PCI, CPUID, MSR and Power Table. 项目地址: https:…...
展锐RM500U 5G CPE固件升级避坑指南:为什么你的QFlash总卡在‘开始下载’?
展锐RM500U 5G CPE固件升级疑难解析:从QFlash卡顿到完美升级的实战手册 当你的展锐RM500U 5G CPE设备需要固件升级时,QFlash工具本应是简单高效的解决方案。然而,许多用户在点击"Start"按钮后,却遭遇了进度条停滞不前的…...
