Potrans
Command line tool for translate Gettext with Google Translator API or DeepL API
Install / Use
/learn @OzzyCzech/PotransREADME
PO file translator
Potrans is a PHP command line tool for automatic translation of Gettext PO files with Google Translator or DeepL Translator.
Install
You can add om/potrans to your PHP project as follows:
composer require --dev om/potrans
or you can clone this repository and then run ./bin/potrans
Google Translator
bin/potrans google --help
Description:
Translate PO file with Google Translator API
Usage:
google [options] [--] <input> [<output>]
Arguments:
input Input PO file path
output Output PO, MO files directory [default: input file directory]
Options:
--from=FROM Source language (default: en) [default: "en"]
--to=TO Target language (default: cs) [default: derived from input file name]
--dir=DIR Root directory (default: current working directory)
--force Force re-translate including translated sentences
--only Create only PO file, no MO file
--wait=WAIT Wait between translations in milliseconds [default: false]
--credentials=CREDENTIALS Path to Google Credentials file [default: "./credentials.json"]
--project=PROJECT Google Cloud Project ID [default: project_id from credentials.json]
--location=LOCATION Google Cloud Location [default: "global"]
--translator[=TRANSLATOR] Path to custom translator instance
--cache|--no-cache Load from cache or not
-h, --help Display help for the given command. When no command is given display help for the list command
-q, --quiet Do not output any message
-V, --version Display this application version
--ansi|--no-ansi Force (or disable --no-ansi) ANSI output
-n, --no-interaction Do not ask any interactive question
-v|vv|vvv, --verbose Increase the verbosity of messages: 1 for normal output, 2 for more verbose output and 3 for debug
Example commands
Follow command will translate whole content of tests/example-cs_CZ.po from English (default) to Czech language (
default):
bin/potrans google tests/example-cs_CZ.po ~/Downloads \
--credentials=your-credentials-file.json
You can also change source and target language with --form and --to parametters:
bin/potrans google tests/example-cs_CZ.po ~/Downloads \
--credentials=your-credentials-file.json \
--from=en \
--to=de
Google Translate API Pricing
Google Translate API pricing is based on usage. Translation usage is calculated in millions of characters (M), where 1 M = 10^6 characters. For more information, see the Pricing FAQ.
Getting Google Translation Credentials
- Open Google Cloud Console website
- Create a new Project (or select existing one)
- Search for translate API and enable it then
- Go to IAM & Admin > Service Accounts and click to + Create service account
- Chose Service account name and Service account ID and click to Create and continue
- Grant this service account access to project and add follow roles Cloud Translation API Editor, AutoML Editor
- Create new Keys and download credentials JSON file
You can watch it here:
<img src="https://img.youtube.com/vi/SCyP1AN2-EE/maxresdefault.jpg" width="50%" style="margin:auto">
DeepL Translator
bin/potrans deepl --help
Description:
Translate PO file with DeepL Translator API
Usage:
deepl [options] [--] <input> [<output>]
Arguments:
input Input PO file path
output Output PO, MO files directory [default: input file directory]
Options:
--from=FROM Source language (default: en) [default: "en"]
--to=TO Target language (default: cs) [default: derived from input file name]
--dir=DIR Root directory (default: current working directory)
--force Force re-translate including translated sentences
--only Create only PO file, no MO file
--wait=WAIT Wait between translations in milliseconds [default: false]
--apikey=APIKEY Deepl API Key
--translator[=TRANSLATOR] Path to custom translator instance
--cache|--no-cache Load from cache or not
-h, --help Display help for the given command. When no command is given display help for the list command
-q, --quiet Do not output any message
-V, --version Display this application version
--ansi|--no-ansi Force (or disable --no-ansi) ANSI output
-n, --no-interaction Do not ask any interactive question
-v|vv|vvv, --verbose Increase the verbosity of messages: 1 for normal output, 2 for more verbose output and 3 for debug
Example commands
bin/potrans deepl tests/example-cs_CZ.po ~/Downloads --from=en --to=cs --apikey=<your-deepl-api-key> -vvv
DeepL Translator API pricing
DeepL Translator API pricing is based on a monthly subscription. There is a maximum of 500,000 characters/month for free.
For more information, visit DeepL Pro API.
Getting Api Key
- Register free Account
- Visit Account summary
- Find the Authentication Key for the DeepL API.
Environment variables
You can use environment variables to set the DeepL API key.
DEEPL_API_KEY=<your-deepl-api-key>
Custom translator
If you need to use a custom translator that behaves differently than the original translator, you have the option to use
the --translator parameter as follows:
./bin/potrans deepl ./tests/example-cs_CZ.po ~/Downloads \
--translator=path/to/my/CustomTranslator.php \
--apikey=<your-deepl-api-key>
PHP file should contain implementation of Translator interface and should return new instance:
<?php
class CustomTranslator implements \potrans\translator\Translator {
// TODO add your code
}
return new CustomTranslator();
You can find an example custom translator in the file DeepLTranslatorEscaped.php
Potrans development
- Install composer
curl -s http://getcomposer.org/installer | php - Run
composer installfor install all dependencies - Install PHP Curl extension (curl and json PHP extensions)
For more information about Composer, visit: https://getcomposer.org
If you get "command not found: potrans", just run the command like this: php bin/potrans and it will run without
problems.
Troubleshooting
cURL error: SSL certificate issue (Google Translate only)
You may encounter a problem caused by cURL like the following:
cURL error 60: SSL certificate problem: unable to get local issuer certificate (see https://curl.haxx.se/libcurl/c/libcurl-errors.html)
This is due to a missing issuer certificate cacert.pem file, and curl won't verify SSL requests:
- Download http://curl.haxx.se/ca/cacert.pem
- Save is somewhere, e.g.
/usr/local/etc/cacert.pem - Update your
php.iniwith the following:
curl.cainfo = "/usr/local/etc/cacert.pem"
openssl.cafile = "/usr/local/etc/cacert.pem"
You can verify it with phpinfo() or php --info. Read more
detailed instruction here.
Links
Related Skills
node-connect
344.4kDiagnose OpenClaw node connection and pairing failures for Android, iOS, and macOS companion apps
frontend-design
99.2kCreate distinctive, production-grade frontend interfaces with high design quality. Use this skill when the user asks to build web components, pages, or applications. Generates creative, polished code that avoids generic AI aesthetics.
openai-whisper-api
344.4kTranscribe audio via OpenAI Audio Transcriptions API (Whisper).
qqbot-media
344.4kQQBot 富媒体收发能力。使用 <qqmedia> 标签,系统根据文件扩展名自动识别类型(图片/语音/视频/文件)。
