如题。通过 type 函数创建一个类,如何生成这个类的 python 代码的形式? 我有一个 json,类似这样
{
"table_name": "student",
"columns": [
{"name": "name", "type": "str"},
{"name": "gender", "type": "str"},
{"name": "age", "type": "int"}
]
}
我想用代码生成一个 py 文件,里面是 sqlalchemy 的 model,类似这样
class Student(BaseModel):
name = Column(String(64), nullable=False)
gender = Column(String(1), nullable=False)
age = Column(BigInteger, nullable=False)
我的想法是用 jinja2 写一个模版,然后往里面填充数据,类似这样
class {{ class_name }} (BaseModel):
{% for column in columns %}
{{column.name}} = Column({{blablablabla}})
{% endfor %}
但是感觉这样的方法太笨拙了,请问有高级一点的实现方式吗?比如通过 json, 先用 type()生成一个 model,然后把这个内存对象逆向成字节码,再通过字节码还原成 python 代码??? 不知道我有没有描述清楚,请大佬们帮帮忙
1
ruanimal 2021-05-07 17:05:29 +08:00 1
sqlalchemy 可以自动映射表, 不需要手动生成文件
|