python读取excel自动化生成sql建表语句和java实体类字段

1、首先准备一个excel文件:

 

idtypename
idint学号
namestring姓名
ageint年龄
sexstring性别
weightdecimal(20,4)体重
scoredecimal(20,4)分数

2、直接生成java字段和注释:

import pandas as pddf = pd.read_excel('test.xlsx', sheet_name='Sheet1')for i in range(len(df.values)):data_type = ''if df['type'][i] == 'bigint':data_type = "Long"elif df['type'][i] == 'int':data_type = "Integer"elif df['type'][i] == 'string':data_type = "String"elif df['type'][i] == 'decimal(20,4)':data_type = "Double"strs = "/**\n* " + df['name'][i] + "\n*/\n"str_entity = strs + 'private' + ' ' + data_type + ' ' + df['id'][i] + ';'print(str_entity)

3、生成建表语句:

import pandas as pddf = pd.read_excel('test.xlsx', sheet_name='Sheet1')str1 = 'create table student' + ' ' + '(' + '\n'
str2 = ")"
for i in range(len(df.values)):data_type = ''if df['type'][i] == 'bigint':data_type = "bigint(20)"elif df['type'][i] == 'int':data_type = "int(11)"elif df['type'][i] == 'string':data_type = "varchar(20)"elif df['type'][i] == 'decimal(20,4)':data_type = "decimal(20,4)"str = '`' + df['id'][i] + '`' + ' ' + data_type + ' ' + 'NOT NULL COMMENT' + ' ' + "'" + df['name'][i] + "'" + ','str1 = str1 + str + '\n'
# 删除末尾换行符和","
str1 = str1[:-2]
str1 = str1 + str2 + ';'
print(str1)

结果:

可以根据实际需求增加主键或其它约束。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/231318.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

算法通关村-----超大规模数据场景的问题

对20GB文件进行排序 问题描述 假设有一个20GB的文件,每行一个字符串,请说明如何对这个文件进行排序 问题分析 20GB的文件很难一次加载到内存中,可以采用分块策略,先使块内有序,在使块间有序。 实现思路 按照给定…

mock技术在测试中的应用

技术简介 mock技术又叫测试桩、挡板 在软件测试中,对于一些不容易构造、获取的对象,用一个虚拟的对象来代替它,以达到相同的效果,这个虚拟的对象就是mock。 mock技术并不是只有测试领域用,最早是在开发领域应用&…

【长文干货】Python可视化教程

文章目录 数据介绍Matplotlib散点图折线图柱形图直方图 Seaborn散点图折线图柱形图直方图 Bokeh散点图折线条形图交互式 Plotly基本组合优化:定制化下拉菜单 总结 数据介绍 在这个小费数据集中,我们记录了20世纪90年代初期餐厅顾客在两个半月内给出的小…

贪心 53. 最大子序和 122.买卖股票的最佳时机 II

53. 最大子序和 题目: 给定一个数组,有正有负,找出一个连续子序列的总和最大(子数组最少一个) 暴力思路: 双层for循环,记录每一次可能的子序列的总和,初始为整数最小值&#xff…

windows+deepin v23 linux 双系统 安装前后 与 删除后 的硬盘efi分区情况,deepin v23 beta2的一些体验

知乎版:https://zhuanlan.zhihu.com/p/669429404 windows下安装deepin v23 beta2 电脑8GB内存,一个256GB固态硬盘,已经安装windows11。 安装双系统前分区情况:主要包含 windows EFI分区 和 系统分区,并预留了64GB给d…

Python将Labelme的Json标注文件进行增、删、改、查

Python将Labelme的Json标注文件进行增、删、改、查 前言前提条件相关介绍实验环境Json标注文件的增、删、改、查增代码实现输出结果 删代码实现输出结果 改代码实现输出结果 查代码实现输出结果 前言 由于本人水平有限,难免出现错漏,敬请批评改正。更多精…

【数值计算方法(黄明游)】常微分方程初值问题的数值积分法:欧拉方法(向后Euler)【理论到程序】

文章目录 一、数值积分法1. 一般步骤2. 数值方法 二、欧拉方法(Euler Method)1. 向前欧拉法(前向欧拉法)2. 向后欧拉法(后向欧拉法)a. 基本理论b. 算法实现 常微分方程初值问题的数值积分法是一种通过数值方…

uniapp打包ios有时间 uniapp打包次数

我们经常用的解决方案有,分包,将图片上传到服务器上,减少插件引入。但是还有一个方案好多刚入门uniapp的人都给忽略了,就是在源码视图中配置,开启分包优化。 1.分包 目前微信小程序可以分8个包,每个包的最大存储是2M,也就是说你文件总体的大小不能超过16M,每个包的大…

智能优化算法应用:基于闪电搜索算法无线传感器网络(WSN)覆盖优化 - 附代码

智能优化算法应用:基于闪电搜索算法无线传感器网络(WSN)覆盖优化 - 附代码 文章目录 智能优化算法应用:基于闪电搜索算法无线传感器网络(WSN)覆盖优化 - 附代码1.无线传感网络节点模型2.覆盖数学模型及分析3.闪电搜索算法4.实验参数设定5.算法结果6.参考…

Unity中Shader变体优化

文章目录 前言一、在Unity中查看变体个数,以及有哪些变体二、若使用预定义的变体太多,我们只使用其中的几个变体,我们该怎么做优化一:可以直接定义需要的那个变体优化二:使用 skip_variants 剔除不需要的变体 三、变体…

创建Asp.net MVC项目Ajax实现视图页面数据与后端Json传值显示

简述回顾 继上篇文章创建的mvc传值这里说明一下Json传值。在mvc框架中,不可避免地会遇到前台传值到后台,前台接收后台的值的情况(前台指view,后台指controller),有时只需要从控制器中返回一个处理的结果&a…

开源英伟达 Vulkan 驱动程序 NVK 达到 Vulkan 1.0 标准

导读Collabora今天宣布,其开源NVK图形驱动程序Mesa现已正式符合英伟达图灵硬件上的Vulkan 1.0图形应用程序接口。 “这是任何Nouveau驱动程序首次在任何API上获得Khronos一致性徽章”。Collabora表示,NVK获得Vulkan官方认证是Nouveau图形驱动程序首次在…