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、端口扫描原…...
Java - Mysql数据类型对应
Mysql数据类型java数据类型备注整型INT/INTEGERint / java.lang.Integer–BIGINTlong/java.lang.Long–––浮点型FLOATfloat/java.lang.FloatDOUBLEdouble/java.lang.Double–DECIMAL/NUMERICjava.math.BigDecimal字符串型CHARjava.lang.String固定长度字符串VARCHARjava.lang…...

el-switch文字内置
el-switch文字内置 效果 vue <div style"color:#ffffff;font-size:14px;float:left;margin-bottom:5px;margin-right:5px;">自动加载</div> <el-switch v-model"value" active-color"#3E99FB" inactive-color"#DCDFE6"…...

从零开始打造 OpenSTLinux 6.6 Yocto 系统(基于STM32CubeMX)(九)
设备树移植 和uboot设备树修改的内容同步到kernel将设备树stm32mp157d-stm32mp157daa1-mx.dts复制到内核源码目录下 源码修改及编译 修改arch/arm/boot/dts/st/Makefile,新增设备树编译 stm32mp157f-ev1-m4-examples.dtb \stm32mp157d-stm32mp157daa1-mx.dtb修改…...

HBuilderX安装(uni-app和小程序开发)
下载HBuilderX 访问官方网站:https://www.dcloud.io/hbuilderx.html 根据您的操作系统选择合适版本: Windows版(推荐下载标准版) Windows系统安装步骤 运行安装程序: 双击下载的.exe安装文件 如果出现安全提示&…...

04-初识css
一、css样式引入 1.1.内部样式 <div style"width: 100px;"></div>1.2.外部样式 1.2.1.外部样式1 <style>.aa {width: 100px;} </style> <div class"aa"></div>1.2.2.外部样式2 <!-- rel内表面引入的是style样…...
Axios请求超时重发机制
Axios 超时重新请求实现方案 在 Axios 中实现超时重新请求可以通过以下几种方式: 1. 使用拦截器实现自动重试 import axios from axios;// 创建axios实例 const instance axios.create();// 设置超时时间 instance.defaults.timeout 5000;// 最大重试次数 cons…...

【OSG学习笔记】Day 16: 骨骼动画与蒙皮(osgAnimation)
骨骼动画基础 骨骼动画是 3D 计算机图形中常用的技术,它通过以下两个主要组件实现角色动画。 骨骼系统 (Skeleton):由层级结构的骨头组成,类似于人体骨骼蒙皮 (Mesh Skinning):将模型网格顶点绑定到骨骼上,使骨骼移动…...

selenium学习实战【Python爬虫】
selenium学习实战【Python爬虫】 文章目录 selenium学习实战【Python爬虫】一、声明二、学习目标三、安装依赖3.1 安装selenium库3.2 安装浏览器驱动3.2.1 查看Edge版本3.2.2 驱动安装 四、代码讲解4.1 配置浏览器4.2 加载更多4.3 寻找内容4.4 完整代码 五、报告文件爬取5.1 提…...

C++ Visual Studio 2017厂商给的源码没有.sln文件 易兆微芯片下载工具加开机动画下载。
1.先用Visual Studio 2017打开Yichip YC31xx loader.vcxproj,再用Visual Studio 2022打开。再保侟就有.sln文件了。 易兆微芯片下载工具加开机动画下载 ExtraDownloadFile1Info.\logo.bin|0|0|10D2000|0 MFC应用兼容CMD 在BOOL CYichipYC31xxloaderDlg::OnIni…...
.Net Framework 4/C# 关键字(非常用,持续更新...)
一、is 关键字 is 关键字用于检查对象是否于给定类型兼容,如果兼容将返回 true,如果不兼容则返回 false,在进行类型转换前,可以先使用 is 关键字判断对象是否与指定类型兼容,如果兼容才进行转换,这样的转换是安全的。 例如有:首先创建一个字符串对象,然后将字符串对象隐…...