Flask-Multilang:为Flask和SQLAlchemy应用添加多语言支持

Flask是一个轻量级的Python Web开发框架,允许开发者快速构建Web应用程序。而SQLAlchemy是Python中最流行的对象关系映射(ORM)库,用于便捷操作数据库对象。当开发多语言网站时,我们需要一种机制处理不同语言的文本,这就是Flask-Multilang的作用。它为Flask应用程序添加了对多语言的支持,使用国际化(i18n)和本地化(l10n)技术,实现多语言切换和内容适配。

Flask-Multilang的主要特性:

  1. 动态语言切换:允许用户在应用运行时选择首选语言,通常通过浏览器的Accept-Language头或界面中的语言切换器实现。

  2. 模板支持:与Flask的Jinja2模板引擎紧密集成,可在模板中插入多语言文本,如{{ _('Hello, World!') }}将根据当前语言返回对应翻译。

  3. 数据库集成:支持通过SQLAlchemy存储翻译,灵活管理翻译文本。

  4. URL语言参数:可将语言代码作为URL的一部分,例如example.com/en/aboutexample.com/de/ueber,有助于SEO优化。

  5. 回退机制:若无特定语言的翻译,将自动回退至默认语言。

Flask-Multilang使用指南:

  1. 安装Flask-Multilang:

pip install flask-multilang

  1. 在Flask应用中初始化插件并设置可用语言列表:

from flask import Flask

from flask_multilang import Multilang

app = Flask(__name__)

multilang = Multilang(app, languages=['en', 'de'])



@app.route('/')

def index():

    return multilang.gettext('Hello, World!')

  1. 创建翻译文件(如.pot文件)并为每种语言编写翻译。若使用SQLAlchemy存储翻译,还需创建数据模型并在应用启动时加载它们:

from flask_sqlalchemy import SQLAlchemy

db = SQLAlchemy(app)



class Translation(db.Model):

    id = db.Column(db.Integer, primary_key=True)

    lang = db.Column(db.String(5), nullable=False)

    key = db.Column(db.String(255), nullable=False, unique=True)

    text = db.Column(db.Text, nullable=False)



multilang.init_db(Translation)