JSON5
AI-перевод файлов JSON5 с помощью Lingo.dev CLI
Что такое JSON5?
JSON5 — это расширение формата JSON, которое упрощает ручное написание и поддержку файлов. Он поддерживает комментарии, некавычённые ключи, завершающие запятые и более гибкий синтаксис, оставаясь совместимым с JavaScript.
Например:
{
// JSON5 allows comments!
title: "Hello, world!",
description: "A simple demo app with JSON5 features",
// Unquoted keys are allowed
author: {
name: "John Doe",
},
messages: ["Welcome to MyApp", "Hello, world!"],
// Trailing commas are allowed
locked_key_1: "This value is locked and should not be changed",
}
Что такое Lingo.dev CLI?
Lingo.dev CLI — это бесплатный open-source CLI для перевода приложений и контента с помощью ИИ. Он создан, чтобы заменить традиционные системы управления переводами и легко интегрируется в существующие пайплайны.
Подробнее см. в разделе Обзор.
О данном руководстве
В этом гайде рассказывается, как переводить файлы JSON5 с помощью Lingo.dev CLI.
Вы узнаете, как:
- Создать проект с нуля
- Настроить пайплайн для перевода
- Генерировать переводы с помощью ИИ
Необходимые условия
Для работы с Lingo.dev CLI убедитесь, что установлен Node.js v18+ :
❯ node -v
v22.17.0
Шаг 1. Создайте проект
В директории вашего проекта создайте файл i18n.json:
{
"$schema": "https://lingo.dev/schema/i18n.json",
"version": "1.10",
"locale": {
"source": "en",
"targets": ["es"]
},
"buckets": {}
}
Этот файл определяет поведение пайплайна перевода: какие языки использовать и где на файловой системе находится локализуемый контент.
Подробнее о доступных свойствах см. в разделе i18n.json.
Шаг 2. Настройте исходную локаль
Исходная локаль — это оригинальный язык и регион, на которых был написан ваш контент. Чтобы её настроить, укажите свойство locale.source в файле i18n.json:
{
"$schema": "https://lingo.dev/schema/i18n.json",
"version": "1.10",
"locale": {
"source": "en",
"targets": ["es"]
},
"buckets": {}
}
Исходная локаль должна быть указана в формате BCP 47 language tag.
Полный список кодов локалей, поддерживаемых Lingo.dev CLI, смотрите в разделе Поддерживаемые коды локалей.
Шаг 3. Настройте целевые локали
Целевые локали — это языки и регионы, на которые вы хотите перевести свой контент. Чтобы настроить целевые локали, укажите свойство locale.targets в файле i18n.json:
{
"$schema": "https://lingo.dev/schema/i18n.json",
"version": "1.10",
"locale": {
"source": "en",
"targets": ["es"]
},
"buckets": {}
}
Шаг 4. Создайте исходный контент
Если вы ещё не сделали этого, создайте один или несколько файлов JSON5 с контентом для перевода. Эти файлы должны находиться по пути, который содержит исходную локаль (например, в виде имени каталога как en/ или как часть имени файла, например messages.en.json5).
Шаг 5. Создайте bucket
-
В файле
i18n.jsonдобавьте объект"json5"в объектbuckets:{ "$schema": "https://lingo.dev/schema/i18n.json", "version": "1.10", "locale": { "source": "en", "targets": ["es"] }, "buckets": { "json5": {} } } -
В объекте
"json5"определите массив из одного или нескольких паттерновinclude:{ "$schema": "https://lingo.dev/schema/i18n.json", "version": "1.10", "locale": { "source": "en", "targets": ["es"] }, "buckets": { "json5": { "include": ["./[locale]/example.json5"] } } }Эти паттерны определяют, какие файлы переводить.
Сами паттерны:
- должны содержать
[locale]как плейсхолдер для выбранной локали - могут указывать на пути к файлам (например,
"[locale]/config.json5") - могут использовать звёздочки как подстановочные знаки (например,
"[locale]/*.json5")
Рекурсивные glob-паттерны (например,
**/*.json5) не поддерживаются. - должны содержать
Шаг 6. Настройте LLM
Lingo.dev CLI использует большие языковые модели (LLM) для AI-перевода контента. Чтобы использовать одну из этих моделей, вам нужен API-ключ от поддерживаемого провайдера.
Чтобы быстро начать, рекомендуем использовать Lingo.dev Engine — нашу облачную платформу с 10 000 бесплатных токенов в месяц:
-
Выполните следующую команду:
npx lingo.dev@latest loginЭто откроет ваш браузер по умолчанию и попросит пройти аутентификацию.
-
Следуйте инструкциям.
Шаг 7. Генерация переводов
В каталоге, где находится файл i18n.json, выполните следующую команду:
npx lingo.dev@latest run
Эта команда:
- Считывает файл
i18n.json. - Находит файлы, которые нужно перевести.
- Извлекает переводимый контент из файлов.
- Использует настроенную LLM для перевода извлечённого контента.
- Записывает переведённый контент обратно в файловую систему.
При первой генерации переводов создаётся файл i18n.lock. Этот файл отслеживает, какой контент уже переведён, чтобы избежать лишних повторных переводов при следующих запусках.
Пример
en/example.json5
{
// JSON5 allows comments!
title: "Hello, world!",
description: "A simple demo app with JSON5 features",
version: "1.0.0",
support_email: "[email protected]",
homepage: "https://lingo.dev",
deprecated: null,
empty: "",
emoji: "🚀",
// Unquoted keys are allowed
author: {
name: "John Doe",
},
contributors: [{ name: "Alice" }, { name: "Bob" }],
messages: ["Welcome to MyApp", "Hello, world!"],
config: {
theme: {
primary: "Blue theme",
},
},
mixed_array: [
"Mixed content here",
42,
true,
{
nested_message: "Nested text",
},
],
// Hexadecimal numbers work in JSON5
hex_value: 0xdeadbeef,
// Trailing commas are allowed
locked_key_1: "This value is locked and should not be changed",
}
es/example.json5
{
// JSON5 allows comments!
title: "¡Hola, mundo!",
description: "Una aplicación de demostración simple con características JSON5",
version: "1.0.0",
support_email: "[email protected]",
homepage: "https://lingo.dev",
deprecated: null,
empty: "",
emoji: "🚀",
// Unquoted keys are allowed
author: {
name: "Juan Pérez",
},
contributors: [{ name: "Alicia" }, { name: "Roberto" }],
messages: ["Bienvenido a MyApp", "¡Hola, mundo!"],
config: {
theme: {
primary: "Tema azul",
},
},
mixed_array: [
"Contenido mixto aquí",
42,
true,
{
nested_message: "Texto anidado",
},
],
// Hexadecimal numbers work in JSON5
hex_value: 0xdeadbeef,
// Trailing commas are allowed
locked_key_1: "This value is locked and should not be changed",
}
i18n.json
{
"version": "1.10",
"locale": {
"source": "en",
"targets": ["es"]
},
"buckets": {
"json5": {
"include": ["./[locale]/example.json5"],
"lockedKeys": ["locked_key_1"]
}
},
"$schema": "https://lingo.dev/schema/i18n.json"
}
i18n.lock
version: 1
checksums:
455da9346f4e772000927cd2ff5bb898:
title: 0468579ef2fbc83c9d520c2f2f1c5059
description: 6f4922f45568161a8cdf4ad2299f6d23
version: 54a9e730e88fb16291b852274d433923
support_email: 10627fcc465897af0f5e1bba042685f9
emoji: b328c432cee108a87a92f05258b6a651
author/name: febee8e9ab40b2fe5106d72675228d00
contributors/0/name: e80d4063a32adaad7b0a82b0bcc10551
contributors/1/name: b2bca2fa3c890618e56d07473f26ead3
messages/0: d1c3a9f35e377554a4ccaa467ca26614
messages/1: 0468579ef2fbc83c9d520c2f2f1c5059
config/theme/primary: 7535a3779d6934ea8ecf18f5cb5b93fd
mixed_array/0: 001b5b003d96c133534f5907abffdf77
mixed_array/3/nested_message: 5f0782dfc5993e99890c0475bc295a30
hex_value: a1b2c3d4e5f6789012345678abcdef01