Skip to main content

Генератор моделей sqlalchemy из таблиц базы данных

Project description

db-model-generator

Пакет для автоматической генерации моделей SQLAlchemy и форм WTForms на основе таблиц базы данных.

Установка

pip install db-model-generator

Использование

Командная строка

Основная команда для использования из командной строки:

db-model-generator [ОПЦИИ] DATABASE TABLE_NAME [OUTPUT] [CONFIG]

Основные аргументы:

  • database - URL базы данных (например: sqlite:///example.db)

  • table_name - имя таблицы для генерации

  • output - имя выходного файла (опционально)

  • config - путь к JSON файлу конфигурации (опционально)

Опции:

  • --database, --table-name, --output, --config - альтернативный способ указания основных аргументов

  • --default-rename, -r - переименовать классы в Model и Form

  • --only-model, -m - создать только модель

  • --only-form, -f - создать только форму

  • --classic-sqlalchemy, -s - создать модель sqlalchemy вместо flask_sqlalchemy

  • --tab, -t - заменить 4 пробела символом табуляции \t

  • --translate-labels, -l - перевести labels в форме (указать код языка)

  • --label-original-language - оригинальный язык labels (по умолчанию: 'en')

  • --log-mode, --log, -V, -L - включить логирование

  • --version, -v - показать версию пакета

  • --env, -e - путь к файлу окружения (.env)

  • --submit-button, --submit, -s - текст для кнопки submit (если не указан, то кнопка не добавляется)

Примеры использования:

# Базовая генерация модели и формы
db-model-generator sqlite:///example.db users

# Генерация только модели
db-model-generator sqlite:///example.db users --only-model

# Генерация с сохранением в файл
db-model-generator sqlite:///example.db users models.py

# Использование конфигурационного файла
db-model-generator sqlite:///example.db users --config config.json

# Перевод labels на русский язык
db-model-generator sqlite:///example.db users --translate-labels ru

# Классический SQLAlchemy вместо Flask-SQLAlchemy
db-model-generator sqlite:///example.db users --classic-sqlalchemy

# Убрать кнопку подтверждения из формы
db-model-generator sqlite:///example.db users --submit-button "Send"

Использование в Python

from db_model_generator import generate

# Базовая генерация
generate(
    database="sqlite:///example.db",
    table_name="users"
)

# Расширенная генерация с опциями
generate(
    database="sqlite:///example.db",
    table_name="users",
    output="models.py",
    config="config.json",
    only_model=True,
    classic_sqlalchemy=False,
    translate_labels="ru",
    log_mode=True,
    submit='Send'
)

Параметры функции generate():

  • database (str) - URL базы данных

  • table_name (str) - имя таблицы

  • output (str, опционально) - путь к выходному файлу

  • config (str, опционально) - путь к JSON файлу конфигурации

  • default_rename (bool) - переименовать классы в Model и Form

  • only_model (bool) - генерировать только модель

  • only_form (bool) - генерировать только форму

  • classic_sqlalchemy (bool) - использовать классический SQLAlchemy

  • tab (bool) - использовать табуляцию вместо пробелов

  • translate_labels (str, опционально) - код языка для перевода labels

  • label_original_language (str) - исходный язык labels (по умолчанию 'en')

  • log_mode (bool) - включить логирование

  • env (str, опционально) - путь к файлу окружения

  • submit (str, опционально) - текст для кнопки submit (если None, то кнопка не добавляется)

Конфигурационный файл

Вы можете создать JSON файл конфигурации для настройки генерации:

{
    "model": {
        "base_class": "db.Model",
        "imports": [
            "from flask_sqlalchemy import SQLAlchemy",
            "from datetime import datetime"
        ],
        "exclude_columns": ["created_at", "updated_at"],
        "type_mapping": {
            "string": "db.String",
            "text": "db.Text",
            "integer": "db.Integer",
            "float": "db.Float",
            "boolean": "db.Boolean",
            "datetime": "db.DateTime",
            "date": "db.Date"
        }
    },
    "form": {
        "base_class": "FlaskForm",
        "imports": [
            "from flask_wtf import FlaskForm",
            "from wtforms import StringField, TextAreaField, IntegerField, FloatField, BooleanField, DateField, DateTimeField, SelectField, SubmitField",
            "from wtforms.validators import DataRequired, Email, Length, NumberRange"
        ],
        "field_mapping": {
            "string": "StringField",
            "text": "TextAreaField",
            "integer": "IntegerField",
            "float": "FloatField",
            "boolean": "BooleanField",
            "datetime": "DateTimeField",
            "date": "DateField"
        },
        "default_validators": {
            "required": "DataRequired()",
            "email": "Email()"
        },
        "meta": {}
    },
    "arguments": {
        "default_rename": false,
        "only_model": false,
        "only_form": false,
        "classic_sqlalchemy": false,
        "tab": false,
        "translate_labels": null,
        "label_original_language": "en",
        "log_mode": false,
        "submit": "Send"
    }
}

Поддерживаемые языки для перевода

Пакет поддерживает перевод labels форм на множество языков через Google Translate. Полный список поддерживаемых языков доступен в модуле constants.py.

Примеры кодов языков:

  • en - английский

  • ru - русский

  • es - испанский

  • fr - французский

  • de - немецкий

  • zh-cn - китайский (упрощенный)

  • ja - японский

Пример выходного файла

Для таблицы users с колонками id, username, email, created_at:

# Модель SQLAlchemy
from flask_sqlalchemy import SQLAlchemy
from datetime import datetime

db = SQLAlchemy()

class Users(db.Model):
    __tablename__ = 'users'
    
    id = db.Column(db.Integer, primary_key=True)
    username = db.Column(db.String, nullable=False)
    email = db.Column(db.String, nullable=False)

    def __repr__(self):
        return f'<Users {self.id}>'


# Форма WTForms
from flask_wtf import FlaskForm
from wtforms import StringField, TextAreaField, IntegerField, FloatField, BooleanField, DateField, DateTimeField, SelectField, SubmitField
from wtforms.validators import DataRequired, Email, Length, NumberRange

class UsersForm(FlaskForm):
    username = StringField('Username', validators=[DataRequired()])
    email = StringField('Email', validators=[DataRequired(), Email()])
    submit = SubmitField("Отправить")

Зависимости

  • sqlalchemy - для работы с базами данных

  • deep-translator - для перевода labels

  • tab4 - для форматирования кода

  • python-dotenv - для загрузки переменных окружения

  • undefined-python - для реализации некоторых функций

Поддерживаемые СУБД

Пакет работает с любыми СУБД, поддерживаемыми SQLAlchemy:

  • SQLite

  • PostgreSQL

  • MySQL

  • Oracle

  • Microsoft SQL Server

  • и другие

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

db_model_generator-1.2.2.tar.gz (17.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

db_model_generator-1.2.2-py3-none-any.whl (16.0 kB view details)

Uploaded Python 3

File details

Details for the file db_model_generator-1.2.2.tar.gz.

File metadata

  • Download URL: db_model_generator-1.2.2.tar.gz
  • Upload date:
  • Size: 17.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.0

File hashes

Hashes for db_model_generator-1.2.2.tar.gz
Algorithm Hash digest
SHA256 ffebeebc482fd0bf4c48dff74b5c762ea2f0fdb00559df6c707fd857736a4558
MD5 954f1fefb2499a53e3faca00a1a2a1a5
BLAKE2b-256 d6b1cd96d58c1131935edba28e8be606a2e559c45a7108402052bcb7cf05ccf0

See more details on using hashes here.

File details

Details for the file db_model_generator-1.2.2-py3-none-any.whl.

File metadata

File hashes

Hashes for db_model_generator-1.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 48ed74e86461adea277b142cebf191346581a8950d59965bcf0bfc757d06e669
MD5 623892b0d294bf5bf9471ee7a166cf54
BLAKE2b-256 c3954ae8fa278361142408f7bc705d662b243ef9e07cdd098070a1e6efc6aeda

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page