Skip to main content

A custom i18n implementation that is built to be easily used.

Project description

Github | PyPI


Setting up

Start by downloading the package via pip.

python3 -m pip install ezi18n

After that, you can just import it into your file.


Examples

import ezi18n
import random

_ = ezi18n.Translator() # if you don't provide anything in the brackets, it will look for the file's name's language JSON file. If the main file is  main.py, it will look for main_lang.json - unless you provide a base filename (in this case: main) and/or a suffix (by default: _lang)
dice = random.randint(1, 6)
language = input("What's your native language? / Was ist Deine Muttersprache? (en/de) >>> ")

print(_("dice_result", language, dice=dice))
{
   "en": {
       "dice_result": "Your dice rolled {dice}!"
   },
   "de": {
       "dice_result": "Dein Würfel hat eine {dice} gewürfelt!"
   }
}

Working with plurals

import ezi18n
import locale

_ = ezi18n.Translator("main", "_plurals") # this will look for main_plurals.json as the language JSON file
apples = int(input("How many apples do you have? >>> "))
language = locale.getdefaultlocale()[:2] # this will return the default OS language, such as en, hu, de, fr, es etc.

print(_.one("apples", language, apples=apples))
{
   "en": {
       "apples": ["You only have one apple! What a loser...", "You have {apples} apples!"]
   },
   "hu": {
       "apples": ["{apple} almád van!"]
   }
}

This example does a great job at presenting how the .one() function works. Here's the explanation for the code:

The code will look for the default OS language, and will tell you how many apples you have with plurals in mind. I always get angry when I see "you have 1 apples"-ish text on a website, and it's an easy fix, but for some reason, many developers don't pay attention to it.

Hungarian doesn't make a difference between plurals, so the list for "hu"/"apples" only has 1 item. This won't be a problem though - the library isn't hardcoded to only look for the first and second elements in the returned list, it will look for the first and the last. Which means that if a list only has 1 item, it will only return that item.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ezi18n-1.0.2.tar.gz (4.7 kB view details)

Uploaded Source

Built Distribution

ezi18n-1.0.2-py3-none-any.whl (4.7 kB view details)

Uploaded Python 3

File details

Details for the file ezi18n-1.0.2.tar.gz.

File metadata

  • Download URL: ezi18n-1.0.2.tar.gz
  • Upload date:
  • Size: 4.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.6

File hashes

Hashes for ezi18n-1.0.2.tar.gz
Algorithm Hash digest
SHA256 bc2aae1a31863c9197c26fa3a2bce1dadb811933a96607d3579eeee98833265d
MD5 8faa59ce8b6c048a0e6877930c8573b3
BLAKE2b-256 47654a5702303b27a51ab86057286ac651be65ca2e9ec9e553951202cb7c8bf0

See more details on using hashes here.

Provenance

File details

Details for the file ezi18n-1.0.2-py3-none-any.whl.

File metadata

  • Download URL: ezi18n-1.0.2-py3-none-any.whl
  • Upload date:
  • Size: 4.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.6

File hashes

Hashes for ezi18n-1.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 25ddc60f38d5b08c03c006e5539b2da9cb7c62a33590bd65f995a7680f0e8822
MD5 7ed4e68cf9545353728d05a54daa18c5
BLAKE2b-256 2a55c602fb33d44bce461f84f4482e856c7129cea9b6c9851157d6c50e2d4e78

See more details on using hashes here.

Provenance

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page