i18n and l10n support for Flask based on Babel and pytz

Related tags

Flaskflask-babel
Overview

Flask Babel

Tests PyPI

Implements i18n and l10n support for Flask. This is based on the Python babel module as well as pytz both of which are installed automatically for you if you install this library.

Documention

The latest documentation is available here.

Comments
  • Support temporary language switch inside a request

    Support temporary language switch inside a request

    It would be nice to be able to stash the current language somewhere and use another one for a while during a request execution.

    The main use-case I see is sending out emails with Flask-Email. The email should be translated according to the recipient's language and not the current user's language.

    Something like:

    from flaskext.babel import stash, unstash
    
    # do stuff with current user's language
    print _('foo')
    # Now switch to th recipient language
    stash(new_lang=recipient.language)
    send email with i18n tags
    unstash()
    # Now the language is back to the current user's lang
    

    Well the API is terrible, but you get the idea..

    opened by rslinckx 14
  • do not hardcode the translations folder path

    do not hardcode the translations folder path

    This allows to specify in which folder the translations should be looked for instead of having it hardcoded (still defaults to "translations"). This is done either via a folder param passed to the constructor or via the BABEL_TRANSLATIONS_FOLDER configuration variable.

    opened by mdeous 13
  • pybabel fails to update under python-3.3

    pybabel fails to update under python-3.3

    TypeError is being thrown:

    $ pybabel update -i messages.pot -d translations/
    updating catalog 'translations/en/LC_MESSAGES/messages.po' based on 'messages.pot'
    Traceback (most recent call last):
      File "/home/georg/env/main/bin/pybabel", line 9, in <module>
        load_entry_point('Babel==1.3', 'console_scripts', 'pybabel')()
      File "/home/georg/env/main/lib/python3.3/site-packages/babel/messages/frontend.py", line 1151, in main
        return CommandLineInterface().run(sys.argv)
      File "/home/georg/env/main/lib/python3.3/site-packages/babel/messages/frontend.py", line 665, in run
        return getattr(self, cmdname)(args[1:])
      File "/home/georg/env/main/lib/python3.3/site-packages/babel/messages/frontend.py", line 1130, in update
        width=options.width)
      File "/home/georg/env/main/lib/python3.3/site-packages/babel/messages/pofile.py", line 444, in write_po
        _write(comment_header + u'\n')
      File "/home/georg/env/main/lib/python3.3/site-packages/babel/messages/pofile.py", line 388, in _write
        fileobj.write(text)
    TypeError: must be str, not bytes
    
    opened by georgthegreat 12
  • Documentation request - using templates

    Documentation request - using templates

    There should be a short introduction in how to use gettext, trans etc in Jinja the jkji2 templates - it's not obvious from the docs that the jinja2 i18n ext is used and that the user does not need to configure this separately.

    opened by danjac 9
  • Fix locale selection in multi-threaded Flask app when force_locale is used

    Fix locale selection in multi-threaded Flask app when force_locale is used

    This fixes issue #117 by setting babel_locale in force_locale context manager instead of replacing locale getter. Babel extension instance is shared across threads (through Flask.extensions) which may cause wrong locale to be selected in request that is processed at the same time in one thread while another thread is using force_locale. Setting locale to request context is thread-safe as Flask doesn't share request contexts between threads. I've added a test case to verify that this fix works, and it failed without changes to force_locale.

    opened by lautat 8
  • Add basic support for locales unkown by Babel

    Add basic support for locales unkown by Babel

    Right now Flask breaks if you request content in a locale that is unknown by Babel even if the translation files actually exist.

    This commit allows translations to be loaded even if the locale is unknown by Babel. Numbers and datetimes ~are returned directly~ use the default locale as a fallback.

    opened by MarcAbonce 8
  • 'Babel' object has no attribute 'translation_directories'

    'Babel' object has no attribute 'translation_directories'

    I am getting a:

    'Babel' object has no attribute 'translation_directories'

    error after updating Flask-Babel from 0.9 to 0.11.1.

    I found a similar reference at https://github.com/airbnb/superset/issues/847 which claims the issue was flask extension compatibility related.

    I have been looking for any sort of documentation that indicates what flask extensions have compatibility with one another, is it just assumed that the minor version (major.minor.build) must match to be compatible?

    Here are my current application versions that are having the issue:

    Babel (2.3.4) Flask (0.11.1) Flask-Babel (0.11.1) Flask-BabelEx (0.9.3) Flask-Compress (1.3.2) Flask-Login (0.4.0) itsdangerous (0.24) Jinja2 (2.8) MarkupSafe (0.23) pytz (2016.7) setuptools (28.8.0) speaklater (1.3) Werkzeug (0.11.11)

    Again, all works with version 0.9 of flask-babel, just trying to understand if compatibility is the root cause or is there a real issue lurking.

    opened by BGraco 8
  • Bug application context since v0.10

    Bug application context since v0.10

    I use flask_script (and flask_migrate) to migrate my sql schema. Since version 0.10 i got this error. Everything works well with 0.9

    File "/usr/local/lib/python2.7/dist-packages/flask_babel/__init__.py", line 215, in get_translations
      babel = current_app.extensions['babel']
    File "/usr/local/lib/python2.7/dist-packages/werkzeug/local.py", line 343, in __getattr__
      return getattr(self._get_current_object(), name)
    File "/usr/local/lib/python2.7/dist-packages/werkzeug/local.py", line 302, in _get_current_object
      return self.__local()
    File "/usr/local/lib/python2.7/dist-packages/flask/globals.py", line 34, in _find_app
      raise RuntimeError('working outside of application context')
    
    opened by johaven 8
  • how to correctly work out of context

    how to correctly work out of context

    Hi, all. I have two subprocesses. one for flask web(called web.py), and one for some background tasks(called task.py). flask-babel works inside the web context, but also the task subprocess will need some translations. so, I import web app into the task.py and use the app.test_request_context in order to make translations work for me. it works at first but then I found task.py will also get the default language only. here is the web.py:

    app.config['BABEL_DEFAULT_LOCALE'] = 'en'
    babel = Babel(app)
    
    @babel.localeselector
    def get_locale():
        return request.accept_languages.best_match(['zh', 'en'])
    

    task.py

    from web import app
    def task():
        try:
            with app.test_request_context() as ctx:
                sio.emit('loading', {'data': _("please wait a moment.")})
    ....
    

    so how can I get the correct locale before I return the translation?? TIA :)

    opened by wiwengweng 7
  • Not extracting strings from some files

    Not extracting strings from some files

    I have a base.html file and navbar.html file. The navbar.html is included in base.html and base extended in other templates. The problem is that babel does not extract strings from navbar.html even though i can see it read it.

    extraction log

    
    

    babel.cfg

    [jinja2: **.htm*]
    encoding = utf-8
    extensions=jinja2.ext.autoescape,jinja2.ext.with_
    

    What could be the problem?

    opened by osleg 7
  • Domains, caching, etc.

    Domains, caching, etc.

    • Implemented localization domain support
    • If babel is not initialized, gettext/format_date/etc won't crash
    • Localization caching - won't reload translations for each and every request
    • Updated tests
    • Updated docs
    opened by mrjoes 7
  • Babel cannot find words in 3's f-Strings ?

    Babel cannot find words in 3's f-Strings ?

    I have some words in 3's f-Strings sql code. such as

    s = f"""
    SELECT * FROM aa
    balabala ...
    case bala...
    {_("abc")}
    WHERE b=1
    """
    

    after I excute the order $ pybabel extract -F babel.cfg -o messages.pot .

    but I cannot find the words 'abc' from file messages.pot

    opened by teddy-lu 0
  • Babel cannot find words in flask_caching blocks

    Babel cannot find words in flask_caching blocks

    If I have html file content like

    <html>
    {% cache 3600, request.url %}
    <tag>{{ _('h1') }}</tag>
    {% endcache %}
    </html>
    

    And run pybabel extract -F babel.cfg -k _l -o translations/messages.pot .

    Flask Babel cannot find new words in {% cache %} block

    opened by serkin 0
  • question about .mo file caching mechanism

    question about .mo file caching mechanism

    Hi there

    I have a question So we all know that .mo will be cached in flask app I just want to know if when we run flask server it caches all .mo files at the beginning? Or is it just when we switch languages then it creates domain objects and caches that .mo file?

    I thought caching all mo files at the beginning would minimize IO time

    opened by 841020 1
  • Add particular callables to Jinja

    Add particular callables to Jinja

    Now with Flask-Babel it is not possible to use gettext particular callables (pgettext, npgettext) in Jinja templates, but install_gettext_callables() supports it. This PR fixes that.

    opened by czepiec 0
  • pypi page links to defunct documentation

    pypi page links to defunct documentation

    Not a problem with the code itself, but it looks like someone needs to update pypi ... it's the first hit on google for the project, and is still linking to https://flask-babel.tkte.ch/ for the documentation, which doesn't exist.

    opened by mpounsett 0
  • docs: fix simple typo, tranlations -> translations

    docs: fix simple typo, tranlations -> translations

    There is a small typo in flask_babel/init.py.

    Should read translations rather than tranlations.

    Semi-automated pull request generated by https://github.com/timgates42/meticulous/blob/master/docs/NOTE.md

    opened by timgates42 0
Releases(v2.0.0)
  • v2.0.0(Aug 27, 2020)

    Starting with version 2, flask-babel drops official support for Python2. Python versions 3.5 through 3.9-beta1 are tested and supported, as well as pypy3.

    • Tests moved from unittest to pytest (#163)
    • Domain and caching support from Flask-BabelEx (#163)
    • Documentation moved from python-hosted to Github Pages.
    • CI moved from Travisci to Github Actions
    • Small documentation improvements.
    • Removed uncessary checks on get_translations() (#127, #126)
    • localeselector and timezoneselector can be changed after creation.
    Source code(tar.gz)
    Source code(zip)
  • v1.0.0(Feb 6, 2020)

    v1.0.0 - 06/02/2020

    Starting with version 1, flask-babel has changed to Semantic Versioning.

    Changed

    • pytz is an explicit dependency. (#14)
    • pytz.gae, used for Google App Engine, is no longer necessary and has been removed. (#153)
    • Fixed a deprecated werkzeug import (#158).
    • Fix issues switching locales in threaded contexts (#125).
    Source code(tar.gz)
    Source code(zip)
A simple way to demo Flask apps from your machine.

flask-ngrok A simple way to demo Flask apps from your machine. Makes your Flask apps running on localhost available over the internet via the excellen

117 Dec 27, 2022
Harmony, a discord clone, allows users to chat with other users in real time via servers, channels, and direct messages

Harmony, a discord clone, allows users to chat with other users in real time via servers, channels, and direct messages

Seth Holland 3 Feb 03, 2022
Python3🐍 webApp to display your current playing music on OBS Studio.

Spotify Overlay A Overlay to display on Obs Studio or any related video/stream recorder, the current music that is playing on your Spotify. Installati

carlitos 0 Oct 17, 2022
A weather report application build with Python, Flask, and Geopy.

A weather report application build with Python, Flask, and Geopy. Requirements Python 3

Brandon Wallace 6 May 07, 2022
Control YouTube, streaming sites, media players on your computer using your phone as a remote.

Media Control Control Youtube, streaming sites, media players on your computer using your phone as a remote. Installation pip install -r requirements.

Shreyas Daniel 10 Dec 08, 2022
Another redis monitor by using flask, angular, socket.io

RedisPAPA we use redis info to monitor the redis usage. PAPA means a father who is monitoring the redis. accoding to the redis doc, it is be recommand

no13bus 393 Dec 30, 2022
A simple barcode and QR code generator built in Python with Flask.

✨ Komi - Barcode & QR Generator ✨ A simple barcode and QR code generator built in Python with Flask. 📑 Table of Contents Usage Installation Contribut

Bonnie Fave 2 Nov 04, 2021
Connect is a Python Flask project within the cloud-native ecosystem

Connect is a Python Flask project within the cloud-native ecosystem. Second project of Udacity's Cloud Native Nanodegree program, focusing on documenting and architecting a monolith migration to micr

Lauren Ferreira 3 Feb 28, 2022
Flask-template - A simple template for make an flask api

flask-template By GaGoU :3 a simple template for make an flask api notes: you ca

GaGoU 2 Feb 17, 2022
Map Matching & Weight Completion service - Java (Springboot) & Python(Flask)

Map Matching service to match coordinates to roads using Java and Springboot. Weight Completion service to fill in missing weights in a graph, using Python and Flask.

2 May 13, 2022
Boilerplate code for basic flask web apps

Flask Boilerplate This repository contains boilerplate code to start a project instantly It's mainly for projects which you plan to ship in less than

Abhishek 6 Sep 27, 2021
This is a repository for a playlist of videos where I teach building RESTful API with Flask and Flask extensions.

Build And Deploy A REST API with Flask This is code for a series of videos in which we look at the various concepts involved when building a REST API

Ssali Jonathan 10 Nov 24, 2022
Socket.IO integration for Flask applications.

Flask-SocketIO Socket.IO integration for Flask applications. Installation You can install this package as usual with pip: pip install flask-socketio

Miguel Grinberg 4.9k Jan 02, 2023
Adds SQLAlchemy support to Flask

Flask-SQLAlchemy Flask-SQLAlchemy is an extension for Flask that adds support for SQLAlchemy to your application. It aims to simplify using SQLAlchemy

The Pallets Projects 3.9k Dec 29, 2022
Flask Project Template A full feature Flask project template.

Flask Project Template A full feature Flask project template. See also Python-Project-Template for a lean, low dependency Python app. HOW TO USE THIS

Bruno Rocha 96 Dec 23, 2022
A caching extension for Flask

Flask-Caching Adds easy cache support to Flask. This is a fork of the Flask-Cache extension. Flask-Caching also includes the cache module from werkzeu

Peter Justin 774 Jan 02, 2023
A simple Task todo application built with Flask

Task TODO Table An application built with Flask a Python framework and hosted on Heroku. Important notes GuniCorn (Green Unicorn): is a Python WSGI HT

DCN (Dubem Celestine Nwabuisi) 1 Dec 15, 2021
A web application for a fake pizza store, built in Python with Flask and PostgreSQL.

✨ Pizza Pizza - Pizza Store ✨ A web application for a fake Pizza Store, the app let you create an account and order pizza, complements or drinks. Buil

Bonnie Fave 6 Dec 18, 2022
SQL Alchemy dialect for Neo4j

SQL Alchemy dialect for Neo4j This package provides the SQL dialect for Neo4j, using the official JDBC driver (the Neo4j "BI Connector" ) Installation

Beni Ben zikry 8 Jan 02, 2023
Find and notify users in your Active Directory with weak passwords

Crack-O-Matic Find and notify users in your Active Directory with weak passwords. Features: Linux-based Flask-based web app Hashcat or John cracker Au

Adrian Vollmer 92 Dec 31, 2022