由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许可提供。
回到顶部