/sqlalchemy-i18n

Internationalization extension for SQLAlchemy models

Primary LanguagePythonOtherNOASSERTION

SQLAlchemy-i18n

Internationalization extension for SQLAlchemy models.

Features

  • Stores translations in separate tables.
  • Reflects translation table structures based on parent model table structure.
  • Supports forcing of given locale.
  • Good performance (uses proxy dicts and other advanced SQLAlchemy concepts for performance optimization)

Basic Usage

Consider you have already defined SQLAlchemy connections and declarative base as follows:

import sqlalchemy as sa
from sqlalchemy import create_engine
from sqlalchemy.ext.declarative import declarative_base

engine = create_engine(
    'postgres://postgres@localhost/sqlalchemy_i18n'
)
Base = declarative_base()

You only need to define two things, first you have to make the desired mapper translatable using make_translatable() function. Internally this function attaches two sqlalchemy event listeners for given mapper.

NOTICE: Calling make_translatable() for given mapper should happen only once per application.

from sqlalchemy_i18n import make_translatable

make_translatable(sa.orm.mapper)

Secondly you need to define translatable models. You can achieve this by making you models extend Translatable mixin and defining __translated_columns__ class property.

class Article(Base, Translatable):
    __translated_columns__ = [
        sa.Column('name', sa.Unicode(255)),
        sa.Column('content', sa.UnicodeText)
    ]

    id = sa.Column(sa.Integer, autoincrement=True, primary_key=True)

    description = sa.Column(sa.UnicodeText)

Resources