当前位置: 首页 > news >正文

python-Excel数据模型文档转为MySQL数据库建表语句(需要连接数据库)-工作小记

将指定Excel文档转为create table 建表语句。该脚本适用于单一且简单的建表语句

呈现效果

 代码

 

# -*- coding:utf-8 -*-
# @Time : 2023/8/2 17:50
# @Author: 水兵没月
# @File : excel_2_mysql建表语句.py
import reimport pandas as pd
import mysql.connectordb = '库名'mydb = mysql.connector.connect(host="连接IP", user="用户名", password="密码",port='端口',database=db)
def con_mysql():mycursor = mydb.cursor()return mycursordef clo_mysql():mydb.close()def read_xlsx():df = pd.read_excel(r'E:\下载\XXXXXX.xlsx')mylist = df.values.tolist()return mylistdef creat_info(mylist):table = '表名'info = ''CHARSET = 'utf8mb4'COMMENT = '中文表名-注释'otherlist = []for ml in mylist:ml = [_ if not isinstance(_, float) else _ if re.findall(r'\d+',str(_)) else ''  for _ in ml]print(ml)table = ml[0]   # 表名COMMENT = ml[1] # '中文表名-注释'ziduan = ml[3]  # 字段名ziduan_zh = ml[4]   # 注释leixing = ml[5] # 类型changdu = int(ml[6]) if ml[6] else '' # 长度leixing_changdu = leixing if not changdu else leixing+"("+str(changdu)+")"iskong = 'DEFAULT NULL' if ml[-2] == 'Y' or ml[-2] == '' else 'NOT NULL DEFAULT ""'iskong = "NOT NULL DEFAULT"+' 1' if ziduan.upper() in ['ISVALID','DATASTATUS','DATASTATE'] else iskongiskong = "NOT NULL DEFAULT CURRENT_TIMESTAMP" if ziduan.upper() in ['CREATTIME'] else iskongiskong = "NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP" if ziduan.upper() in ['MODIFYTIME','MODIFYUPDATETIME'] else iskongiskong = "NOT NULL AUTO_INCREMENT" if ziduan.upper() in ['ID'] else iskongotherlist.append({ziduan:ml[-3]})info += '`'+ziduan+'`'+' '+leixing_changdu+' '+iskong+' COMMENT '+ "'"+ziduan_zh+"'" +','for ol_dict in otherlist:for k, v in ol_dict.items():if 'PRI' == v:info += "PRIMARY KEY (`{}`),".format(k)elif 'UNI' == v:info += "UNIQUE KEY `{}` (`{}`),".format(k,k)elif 'MUL' == v:info +="KEY `{}` (`{}`) USING BTREE,".format(k,k)info = info.strip(',')creat_table_seq = """CREATE TABLE `{}` ({})ENGINE=InnoDB AUTO_INCREMENT=0 DEFAULT CHARSET={} COMMENT='{}';""".format(table, info, CHARSET, COMMENT)return creat_table_seqdef creat_sel(sel):mycursor = con_mysql()mycursor.execute(sel)mydb.commit()
if __name__ == '__main__':mylist = read_xlsx()sel = creat_info(mylist)creat_sel(sel)

仅作为笔记记录,如有问题请各位大佬来指导 

http://www.lryc.cn/news/110966.html

相关文章:

  • 406 · 和大于S的最小子数组
  • xray的 webhook如何把它Hook住?^(* ̄(oo) ̄)^
  • 浅析RabbitMQ死信队列
  • ELK 企业级日志分析系统(ElasticSearch、Logstash 和 Kiabana 详解)
  • 数学建模—多元线性回归分析
  • win10 64位 vs2017 qt5.12.6 pcl1.9.1 vtk8.1.1配置安装步骤
  • 【项目 计网1】4.1 网络结构模式 4.2MAC地址、IP地址、端口
  • uni-app:分页实现多选功能
  • 问道管理:沪指窄幅震荡跌0.18%,有色、汽车等板块走低
  • Kotlin 协程与 Flow
  • 设备管理系统与物联网的融合:实现智能化设备监控和维护
  • 三、从官方源码精简出第1个FreeRTOS
  • __call__函数的用法
  • golang定时任务库cron实践
  • Julia 流程控制
  • 问题解决方案
  • kubernetes基于helm部署gitlab-operator
  • ChatGPT在在线客服和呼叫中心中的应用如何?
  • C++多线程环境下的单例类对象创建
  • “深入解析JVM内部机制:从字节码到垃圾回收“
  • 音频系统项目与音频算法研究方向分类
  • 单例模式和工厂模式
  • 两个镜头、视野、分辨率不同的相机(rgb、红外)的视野校正
  • kettle 连接jdbc
  • PyTorch中加载模型权重 A匹配B|A不匹配B
  • @FeignClient指定多个url实现负载均衡
  • vue diff 双端比较算法
  • 初识React: 基础(概念 特点 高效原因 虚拟DOM JSX语法 组件)
  • 自监督去噪:Neighbor2Neighbor原理分析与总结
  • 简单工厂模式(Simple Factory)