Files
training.django/documentation/10-translation.md
Steve Kossouho e3ebf6bf4f Add documentation and source
Added documentation, source and extra files.
2025-07-02 20:26:50 +02:00

1.5 KiB

title, author
title author
Django Steve Kossouho

Traduction d'un projet Django (I18N)


Traduction dans le code Django

Pour marquer certaines chaînes dans une application comme étant traduisibles, il suffit de les passer comme arguments de la fonction gettext_lazy. Par convention, on importe la fonction en lui donnant l'alias _.

from django.utils.translation import gettext_lazy as _
_("String to translate")  # dans la langue de `LANGUAGE_CODE`

Traduction dans les templates

Pour accéder aux tags spécifiques à la traduction, vous devez charger les templatetags de l'application i18n :

{% load i18n %}

Traduction dans les templates


Commandes pour la traduction

Dans le répertoire de l'application à traduire :

  • django-admin makemessages -l fr : fichier pour traducteur
  • django-admin compilemessages -l fr : traductions compilées

Bénéficier automatiquement de la traduction

Pour que Django affiche vos pages dans la langue de votre navigateur, il faut ajouter dans MIDDLEWARE une entrée "django.middleware.locale.LocaleMiddleware".

Le middleware récupère depuis les en-têtes HTTP les langues préférées du navigateur, et si possible, active la première langue dont une traduction existe. Cela nécessite donc que le navigateur soit configuré pour préférer l'affichage des pages dans votre langue préférée.

:::notes Faire la démo des langues préférées du navigateur avec Firefox :::