Skip to main content

Automation CLI tool that, using the DeepL API, generates a JSON or a PO file from a given source file.

Project description

Polyglot - Automate translations with DeepL

PyPI PyPI - Downloads PyPI - License

Polyglot is a CLI tool that automates translation tasks and can be easily integrated into your python softwares. Using the DeepL API, Polyglot generates a translated file from a given source file.

alt text

Supported files

Polyglot is born to translate JSON and PO files, but now it supports other files. This is the complete list:

  • json
  • po and pot
  • docx (Microsoft Word)
  • pptx (Microsoft PowerPoint)
  • html and htm
  • pdf
  • raw text files like .txt or .dat

⚠️ If you want to translate PDFs, rember to enable the PDF translations from your DeepL API account.

Installation

Install Python if you haven't already done so, then use pip to install Polyglot.

pip install polyglot-translator

Then you can run Polyglot by running:

python -m polyglot

And that's all.

Soon the whole script will be packaged for other package managers like pacman, apt and brew.

Usage

There are four available commands: translate, set_license, print_usage_data and print_supported_languages.

Translate

"Translate" is the main feature of Polyglot. It reads the passed file and creates one or more new files with the translations. It creates a new file with the translations and doesn't edit the source file.

ℹ️ In the case of a PO and POT files, it returns both a PO and an MO file.

Command options

Option Required Description
-s, --source-file yes The file to be translated.
--to, --target-lang yes the code of the language into which you want to translate the source file
-d, --destination-dir no The directory where the output file will be located. Will be used the working directory if this option is invalid or not used.
--from, --source-lang no Source file language code. Detected automatically by DeepL by default. Specifying it can increase performance and make translations more accurate.

Basic usage

E.g.: we have a .json source in English and we want to translate it in Italian.

python -m polyglot translate -s en.json --to IT

Advanced usage

E.g.: we have a .po source in English and we want a .po file translated into Japanese with the corresponding .mo file in our home. We specify the source language to benefit DeepL.

python -m polyglot translate -s en.po --to JA -d $HOME --from EN-US

Set DeepL API key

DeepL provides you with a key that allows you to use its API. So, Polyglot requires this key to work and will ask you for it on your first use. You can use the following command to set or change the key manually.

python -m polyglot set-license

Print usage info

It returns DeepL usage info related to your API key, run with:

python -m polyglot info

Print supported languages

It returns the list of languages currently supported by DeepL, run with:

python -m polyglot languages

Dependencies

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

polyglot-translator-2.2.4.tar.gz (11.9 kB view details)

Uploaded Source

Built Distribution

polyglot_translator-2.2.4-py3-none-any.whl (13.2 kB view details)

Uploaded Python 3

File details

Details for the file polyglot-translator-2.2.4.tar.gz.

File metadata

  • Download URL: polyglot-translator-2.2.4.tar.gz
  • Upload date:
  • Size: 11.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.9.15

File hashes

Hashes for polyglot-translator-2.2.4.tar.gz
Algorithm Hash digest
SHA256 c07b58c9597ec907174332ce445989ec5d85af6f0ed70ce3ec121bcae2408be4
MD5 4f23e226d6b02f545eae0ba46e62acad
BLAKE2b-256 0f0ff296e467bd70973e7071e7065b24ee99685fb08a42579f7fe9c695bd72ef

See more details on using hashes here.

File details

Details for the file polyglot_translator-2.2.4-py3-none-any.whl.

File metadata

File hashes

Hashes for polyglot_translator-2.2.4-py3-none-any.whl
Algorithm Hash digest
SHA256 f6c6d820fe63979162fc37c1acf9d8d5decc42159170c27187bdd23124bfc80f
MD5 cc6c38bf9d1bfe631920b9ff43ff87ae
BLAKE2b-256 342a6b06e6f4b7e279526d840253cc846d29f86e9408123078db4342f45bc198

See more details on using hashes here.

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