由fotogram.ai贊助 - 用AI將自拍照轉變為傑作
https://fotogram.ai
AI / Free JSON和YAML翻譯人員?
此軟件包將為您提供免費的JSON/YAML文件或JSON對象免費為不同的語言。
| 翻譯模塊 | 支持 | 自由的 |
|---|---|---|
| Google翻譯 | ✅ | ✅ FREE |
| Google翻譯2 | ✅ | ✅ FREE |
| Microsoft Bing翻譯 | ✅ | ✅ FREE |
| libre翻譯 | ✅ | ✅ FREE |
| Argos翻譯 | ✅ | ✅ FREE |
| deepl翻譯 | ✅ | require API KEY (DEEPL_API_KEY as env)optional API URL (DEEPL_API_URL as env) |
| GPT-4O | ✅ | require API KEY (OPENAI_API_KEY as env) |
| GPT-3.5-Turbo | ✅ | require API KEY (OPENAI_API_KEY as env) |
| GPT-4 | ✅ | require API KEY (OPENAI_API_KEY as env) |
| GPT-4O-Mini | ✅ | require API KEY (OPENAI_API_KEY as env) |
| 翻譯模塊 | 支持 | 自由的 |
|---|---|---|
| Google翻譯 | ✅ | ✅ FREE |
| Google翻譯2 | ✅ | ✅ FREE |
| Microsoft Bing翻譯 | ✅ | ✅ FREE |
| libre翻譯 | ✅ | ✅ FREE |
| Argos翻譯 | ✅ | ✅ FREE |
| deepl翻譯 | ✅ | require API KEY (DEEPL_API_KEY as env)optional API URL (DEEPL_API_URL as env) |
| GPT-4O | ✅ | require API KEY (OPENAI_API_KEY as env) |
| GPT-3.5-Turbo | ✅ | require API KEY (OPENAI_API_KEY as env) |
| GPT-4 | ✅ | require API KEY (OPENAI_API_KEY as env) |
| GPT-4O-Mini | ✅ | require API KEY (OPENAI_API_KEY as env) |
Browser support will come soon...
支持的語言
npm i @parvineyvazov/json-translatornpm i -g @parvineyvazov/json-translatorjsontt < your/path/to/file.json >
or
jsontt < your/path/to/file.yaml/yml > [path] :必需的JSON/YAML文件路徑<your/path/to/file.json>[path] :可選代理列表txt文件路徑<your/path/to/proxy_list.txt> -V, --version output the version number
-m, --module <Module> specify translation module
-f, --from <Language> from language
-t, --to <Languages...> to translates
-n, --name <string> optional ↵ | output filename
-fb, --fallback <string> optional ↵ | fallback logic,
try other translation modules on fail | yes, no | default: no
-cl, --concurrencylimit <number> optional ↵ | set max concurrency limit
(higher faster, but easy to get banned) | default: 3
-h, --help display help for command
使用Google Translate轉換JSON文件:
jsontt < your/path/to/file.json > --module google --from en --to ar fr zh-CNjsontt < your/path/to/file.json > --module google --from en --to ar fr zh-CN --name myFilesjsontt < your/path/to/file.json > --module google --from en --to ar fr zh-CN --name myFiles --fallback yesjsontt < your/path/to/file.json > --module google --from en --to ar fr zh-CN --name myFiles --fallback yes --concurrencylimit 10jsontt file.jsonjsontt folder/file.jsonjsontt " folderfile.json " jsontt " C:folder1folderen.json "jsontt file.json proxy.txt結果將與原始JSON/YAML文件相同。
jsontt -hjsontt --help用於JavaScript
const translator = require ( '@parvineyvazov/json-translator' ) ;對於打字稿:
import * as translator from '@parvineyvazov/json-translator' ; // Let`s translate `Home sweet home!` string from English to Chinese
const my_str = await translator . translateWord (
'Home sweet home!' ,
translator . languages . English ,
translator . languages . Chinese_Simplified
) ;
// my_str: 家,甜蜜的家! 用於JavaScript
const translator = require ( '@parvineyvazov/json-translator' ) ;對於打字稿:
import * as translator from '@parvineyvazov/json-translator' ; /*
Let`s translate our deep object from English to Spanish
*/
const en_lang : translator . translatedObject = {
login : {
title : 'Login {{name}}' ,
email : 'Please, enter your email' ,
failure : 'Failed' ,
} ,
homepage : {
welcoming : 'Welcome!' ,
title : 'Live long, live healthily!' ,
} ,
profile : {
edit_screen : {
edit : 'Edit your informations' ,
edit_age : 'Edit your age' ,
number_editor : [
{
title : 'Edit number 1' ,
button : 'Edit 1' ,
} ,
{
title : 'Edit number 2' ,
button : 'Edit 2' ,
} ,
] ,
} ,
} ,
} ;
/*
FOR JavaScript don`t use translator.translatedObject (No need to remark its type)
*/
let es_lang = await translator . translateObject (
en_lang ,
translator . languages . English ,
translator . languages . Spanish
) ;
/*
es_lang:
{
"login": {
"title": "Acceso {{name}}",
"email": "Por favor introduzca su correo electrónico",
"failure": "Fallida"
},
"homepage": {
"welcoming": "¡Bienvenidas!",
"title": "¡Vive mucho tiempo, vivo saludable!"
},
"profile": {
"edit_screen": {
"edit": "Edita tus informaciones",
"edit_age": "Editar tu edad",
"number_editor": [
{
"title": "Editar número 1",
"button": "Editar 1"
},
{
"title": "Editar número 2",
"button": "Editar 2"
}
]
}
}
}
*/ 用於JavaScript
const translator = require ( '@parvineyvazov/json-translator' ) ;對於打字稿:
import * as translator from '@parvineyvazov/json-translator' ; /*
Let`s translate our object from English to French, Georgian and Japanese in the same time:
*/
const en_lang : translator . translatedObject = {
login : {
title : 'Login' ,
email : 'Please, enter your email' ,
failure : 'Failed' ,
} ,
edit_screen : {
edit : 'Edit your informations' ,
number_editor : [
{
title : 'Edit number 1' ,
button : 'Edit 1' ,
} ,
] ,
} ,
} ;
/*
FOR JavaScript don`t use translator.translatedObject (No need to remark its type)
*/
const [ french , georgian , japanese ] = ( await translator . translateObject (
en_lang ,
translator . languages . Automatic ,
[
translator . languages . French ,
translator . languages . Georgian ,
translator . languages . Japanese ,
]
) ) as Array < translator . translatedObject > ; // FOR JAVASCRIPT YOU DO NOT NEED TO SPECIFY THE TYPE
/*
french:
{
"login": {
"title": "Connexion",
"email": "S'il vous plaît, entrez votre email",
"failure": "Manquée"
},
"edit_screen": {
"edit": "Modifier vos informations",
"number_editor": [
{
"title": "Modifier le numéro 1",
"button": "Éditer 1"
}
]
}
}
georgian:
{
"login": {
"title": "Შესვლა",
"email": "გთხოვთ, შეიყვანეთ თქვენი ელ",
"failure": "მცდელობა"
},
"edit_screen": {
"edit": "თქვენი ინფორმაციათა რედაქტირება",
"number_editor": [
{
"title": "რედაქტირების ნომერი 1",
"button": "რედაქტირება 1"
}
]
}
}
japanese:
{
"login": {
"title": "ログイン",
"email": "あなたのメールアドレスを入力してください",
"failure": "失敗した"
},
"edit_screen": {
"edit": "あなたの情報を編集します",
"number_editor": [
{
"title": "番号1を編集します",
"button": "編集1を編集します"
}
]
}
}
*/ 用於JavaScript
const translator = require ( '@parvineyvazov/json-translator' ) ;對於打字稿:
import * as translator from '@parvineyvazov/json-translator' ; /*
Let`s translate our json file into another language and save it into the same folder of en.json
*/
let path = 'C:/files/en.json' ; // PATH OF YOUR JSON FILE (includes file name)
await translator . translateFile ( path , translator . languages . English , [
translator . languages . German ,
] ) ; ── files
├── en.json
└── de.json用於JavaScript
const translator = require ( '@parvineyvazov/json-translator' ) ;對於打字稿:
import * as translator from '@parvineyvazov/json-translator' ; /*
Let`s translate our json file into multiple languages and save them into the same folder of en.json
*/
let path = 'C:/files/en.json' ; // PATH OF YOUR JSON FILE (includes file name)
await translator . translateFile ( path , translator . languages . English , [
translator . languages . Cebuano ,
translator . languages . French ,
translator . languages . German ,
translator . languages . Hungarian ,
translator . languages . Japanese ,
] ) ; ── files
├── en.json
├── ceb.json
├── fr.json
├── de.json
├── hu.json
└── ja.json忽略翻譯上的單詞使用{{word}}或{word}樣式上的對像上的單詞。
{
"one": "Welcome {{name}}",
"two": "Welcome {name}",
"three": "I am {name} {{surname}}"
}
...translating to spanish
{
"one": "Bienvenido {{name}}",
"two": "Bienvenido {name}",
"three": "Soy {name} {{surname}}"
}
jsontt還忽略了文本中的URL ,這意味著在翻譯該字符串時,有時翻譯會破壞給定字符串中的URL。它通過翻譯時忽略字符串中的URL來防止此類情況。
{
"text": "this is a puppy https://shorturl.at/lvPY5"
}
...translating to german
{
"text": "das ist ein welpe https://shorturl.at/lvPY5"
}
git clone https://github.com/mololab/json-translator.git
yarn
展示魔術:
更新CLI
轉到文件src/cli/cli.ts
更新翻譯
轉到文件src/modules/functions.ts
更新JSON操作(深度潛水,發送翻譯請求)
轉到文件src/core/json_object.ts
更新JSON文件讀/寫操作
轉到文件src/core/json_file.ts
更新忽略翻譯中的值(MAP/UNMAP)
轉到文件src/core/ignorer.ts
在本地檢查CLI
要在本地檢查CLI,我們需要使用npm link軟件包
npm link
或者您可以使用Make運行整個步驟
make run-only-cli
在運行這些命令時,請確保您的終端具有管理員訪問權限,以防止任何訪問問題。
✔️翻譯一個單詞|句子
✔️翻譯JSON對象
✔️翻譯深json對象
✔️多語言翻譯為JSON對象
✔️翻譯JSON文件
✔️翻譯深json文件
✔️多語言翻譯為JSON文件
✔️CLI支持
✔️安全翻譯(檢查未定義,長或空值)
✔️隊列支持大型翻譯
✔️向用戶通知翻譯過程(已完成的過程數量,行總數等)
✔️忽略翻譯中的價值單詞(例如忽略{{name}}或{name}在翻譯上)
✔️LIBRE翻譯選項(CLI)
✔️Argos翻譯選項(CLI)
✔️Bing翻譯選項(CLI)
✔️忽略給定字符串上的URL翻譯
語言和源選擇的CLI選項
✔️在CLI上定義輸出文件名(CLI的可選命令)
✔️yaml文件翻譯
✔️後備翻譯(在失敗上嘗試新模塊)
✔️可以手動設置並發限制
libre translate選項(在代碼軟件包中)
argos翻譯選項(在代碼軟件包中)
Bing Translate選項(在代碼軟件包中)
OpenRouter翻譯模塊
cohere翻譯模塊
人類/Claude翻譯模塊
AI翻譯模塊
Llamacpp翻譯模塊
Google Gemini API翻譯模塊
GROQ支持 - 完整列表作為新的翻譯模塊
✔️chatgpt支持
同步翻譯
瀏覽器支持
自己的libranslate實例的翻譯選項
使“ - ”可調節(未翻譯的佔位符)。
@Parvineyvazov/JSON-Translator將根據MIT許可提供。
回到頂部