Internationalization Framework

Basic Usage

from redbot.core import commands
from redbot.core.i18n import Translator, cog_i18n

_ = Translator("ExampleCog", __file__)

class ExampleCog:

    async def mycom(self, ctx):
        """command description"""
        await ctx.send(_("This is a test command"))


After making your cog, generate a messages.pot file

The process of generating this will depend on the operating system you are using

In a command prompt in your cog’s package (where is), create a directory called “locales”. Then do one of the following:

Windows: python <your python install path>\Tools\i18n\ -D -n -p locales

Mac: ?

Linux: pygettext3 -D -n -p locales

This will generate a messages.pot file with strings to be translated, including docstrings.

API Reference


Get a class decorator to link the translator to this cog.

class redbot.core.i18n.Translator(name, file_location)[source]

Bases:, typing.Generic

Function to get translated strings at runtime.


Translate the given string.

This will look for the string in the translator’s .pot file, with respect to the current locale.


Loads the current translations.


Function to convert a locale to a babel.core.Locale.

Parameters:locale (Optional[str]) – The locale to convert, if not specified it defaults to the bot’s locale.
Returns:The babel locale object.
Return type:babel.core.Locale