python将json实例化为class文件 写入.py文件

python将json实例化为class文件 写入.py文件create_class.py

python 复制代码
import json


class Command:
    def handle(self, *args, **kwargs):
        json_file = kwargs['json_file']
        class_name = kwargs['class_name']
        output_file = kwargs['output_file']

        with open(json_file, 'r') as f:
            data = json.load(f)

        class_def = f"class {class_name}:\n"
        for key, value in data.items():
            if not isinstance(value, str):
                class_def += f"    {key} = {value}\n"
            else:
                class_def += f"    {key} = '{value}'\n"

        with open(output_file, 'w') as f:
            f.write(class_def)


if __name__ == "__main__":
    c = Command()
    c.handle(json_file='config.json', class_name="TestClass", output_file='test_01.py')

config.json

powershell 复制代码
{
    "name": "John Doe",
    "age": 31,
    "is_student": false,
    "courses": [
        "Math",
        "Physics",
        "Chemistry",
        "Biology"
    ]
}

运行后即可得到

文件 test_01.py

python 复制代码
class TestClass:
    name = 'John Doe'
    age = 31
    is_student = False
    courses = ['Math', 'Physics', 'Chemistry', 'Biology']

还可以定义模版文件,然后直接写成.py文件

文件:config4_bx.py

python 复制代码
import json

# JSON 数据字符串
json_data = '''
{
    "name": "John Doe",
    "age": 30,
    "is_student": false,
    "courses": ["Math", "Physics", "Chemistry"]
}
'''

# 解析 JSON 数据
data = json.loads(json_data)

# 定义类名
class_name = "Person"
func_name = "BYD_A88"


def func1():
    print('111')


# 生成类定义的模板
class_template = f"""
from src.common.config4_bx import func1

class {class_name}:
    def __init__(self):
{"".join(f'        self.{k} = "{v}"\n' if isinstance(v, str) else f'        self.{k} = {v}\n' for k, v in data.items())}

    def __str__(self):
        return f"{class_name}(name={data.get('name')}, age={data.get('age')}, is_student={data.get('is_student')}, courses={data.get('courses')})"
        
    def test_{func_name}_smoke(self):
        func1()
"""

# 写入 Python 文件
with open('test_person.py', 'w') as file:
    file.write(class_template)

# 输出生成的类定义
print(class_template)
相关推荐
曲幽15 分钟前
别再用网页翻译看源码了!你的私人翻译神器LibreTranslate,部署避坑指南来了
python·docker·web·pot·translate·libretranslate·arogstranslate
用户556918817532 小时前
#从脚本到独立程序:Python + Playwright 批量抓取的完整踩坑记录
python·自动化运维
疯狂SQL2 小时前
手写高性能在线 JSON 工具|Web Worker 工程化打包 + 语法自动修复 + 多语言代码生成实战
typescript·json·next.js·web worker·前端性能优化·esbuild·源码实战
兵慌码乱16 小时前
基于 MediaPipe 与 PySide2 的手势交互音乐控制系统实现:轻量化视觉交互全流程解析
python·opencv·计算机视觉·人机交互·手势识别·mediapipe·pyside2
luckdewei19 小时前
FastAPI 资产管理系统实战:复杂 ORM 关联、Alembic 迁移与 N+1 查询优化
python
aqi001 天前
15天学会AI应用开发(八)使用向量数据库实现RAG功能
人工智能·python·大模型·ai编程·ai应用
Csvn1 天前
`functools.lru_cache` —— 一行代码搞定缓存加速
后端·python
金銀銅鐵2 天前
[Python] 从《千字文》中随机挑选汉字
后端·python
cup112 天前
[技术复盘] Windows Python 打包实战:Nuitka 环境踩坑总结与 CI 自动化构建全指南
python·ai·环境变量·ci·nuitka·skill