Flask从数据库已有表自动生成model

准备

我们需要提前准备两个包,分别是 flask-sqlacodegen 和 psycopg2 安装方式为

pip install flask-sqlacodegen
pip install psycopg2

开始

我们直接使用命令开始生成

# 单张表
flask-sqlacodegen "postgresql://postgres:36o%*********2022@127.0.0.1:5432/situation" --tables TABLENAME --outfile "model.py" --flask
# 多张表
flask-sqlacodegen "postgresql://postgres:36o%*********2022@127.0.0.1:5432/situation" --tables TABLENAME,TABLENAME,TABLENAME --outfile "model.py" --flask
# 全部表
flask-sqlacodegen "postgresql://postgres:36o%*********2022@127.0.0.1:5432/situation" --outfile "model.py" --flask

ps:(大写 “TABLENAME” 要换成自己对应的实际情况)

此步骤有可能会报错,但是没关系,在目录下已经生成了对应文件

 

 

 最后

我们最后在加上 inspect 完成初始化就OK啦!

def __init__(self, **kwargs):
    for c in inspect(self).mapper.column_attrs:
        setattr(self, c.key, kwargs.get(c.key)) if kwargs.get(c.key) else setattr(self, c.key, None)

def to_dict(self):
    return {c.key: getattr(self, c.key) for c in inspect(self).mapper.column_attrs}

 

posted @   你的小可爱吖  阅读(847)  评论(1编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
历史上的今天:
2021-01-11 检查网络问题 是否链接
点击右上角即可分享
微信分享提示