Archivos Properties
Traducción con IA para archivos Java Properties con Lingo.dev CLI
¿Qué son los archivos Properties?
Los archivos Properties son archivos de texto simples de clave-valor comúnmente utilizados en aplicaciones Java para configuración y localización.
Por ejemplo:
app.title=MyApp
app.description=A simple demo application
user.greeting=Hello, world!
user.farewell=Thanks for using MyApp
error.message=Something went wrong
error.notFound=Page not found
¿Qué es Lingo.dev CLI?
Lingo.dev CLI es una CLI gratuita y de código abierto para traducir aplicaciones y contenido con IA. Está diseñada para reemplazar el software tradicional de gestión de traducciones mientras se integra con los pipelines existentes.
Para obtener más información, consulta Descripción general.
Acerca de esta guía
Esta guía explica cómo traducir archivos Properties con Lingo.dev CLI.
Aprenderás a:
- Crear un proyecto desde cero
- Configurar un pipeline de traducción
- Generar traducciones con IA
Requisitos previos
Para usar Lingo.dev CLI, asegúrate de que Node.js v18+ esté instalado:
❯ node -v
v22.17.0
Paso 1. Configurar un proyecto
En el directorio de tu proyecto, crea un archivo i18n.json:
{
"$schema": "https://lingo.dev/schema/i18n.json",
"version": "1.10",
"locale": {
"source": "en",
"targets": ["es"]
},
"buckets": {}
}
Este archivo define el comportamiento del pipeline de traducción, incluyendo entre qué idiomas traducir y dónde existe el contenido localizable en el sistema de archivos.
Para obtener más información sobre las propiedades disponibles, consulta i18n.json.
Paso 2. Configurar el idioma de origen
El idioma de origen es el idioma y región originales en los que se escribió tu contenido. Para configurar el idioma de origen, establece la propiedad locale.source en el archivo i18n.json:
{
"$schema": "https://lingo.dev/schema/i18n.json",
"version": "1.10",
"locale": {
"source": "en",
"targets": ["es"]
},
"buckets": {}
}
El idioma de origen debe proporcionarse como una etiqueta de idioma BCP 47.
Para ver la lista completa de códigos de idioma que admite Lingo.dev CLI, consulta Códigos de idioma admitidos.
Paso 3. Configurar los idiomas de destino
Los idiomas de destino son los idiomas y regiones a los que deseas traducir tu contenido. Para configurar los idiomas de destino, establece la propiedad locale.targets en el archivo i18n.json:
{
"$schema": "https://lingo.dev/schema/i18n.json",
"version": "1.10",
"locale": {
"source": "en",
"targets": ["es"]
},
"buckets": {}
}
Paso 4. Crear el contenido de origen
Si aún no lo has hecho, crea uno o más archivos Properties que contengan el contenido a traducir. Estos archivos deben estar ubicados en una ruta que incluya el idioma de origen en algún lugar de la ruta (por ejemplo, como un nombre de directorio como en/ o como parte del nombre del archivo como messages.en.properties).
Paso 5. Crear un bucket
-
En el archivo
i18n.json, añade un objeto"properties"al objetobuckets:{ "$schema": "https://lingo.dev/schema/i18n.json", "version": "1.10", "locale": { "source": "en", "targets": ["es"] }, "buckets": { "properties": {} } } -
En el objeto
"properties", define un array de uno o más patronesinclude:{ "$schema": "https://lingo.dev/schema/i18n.json", "version": "1.10", "locale": { "source": "en", "targets": ["es"] }, "buckets": { "properties": { "include": ["./[locale]/example.properties"] } } }Estos patrones definen qué archivos traducir.
Los patrones en sí:
- deben contener
[locale]como marcador de posición para el idioma configurado - pueden apuntar a rutas de archivos (por ejemplo,
"[locale]/messages.properties") - pueden usar asteriscos como marcadores de posición comodín (por ejemplo,
"[locale]/*.properties")
No se admiten patrones glob recursivos (por ejemplo,
**/*.properties). - deben contener
Paso 6. Configurar un LLM
Lingo.dev CLI utiliza modelos de lenguaje de gran tamaño (LLM) para traducir contenido con IA. Para usar uno de estos modelos, necesitas una clave API de un proveedor compatible.
Para empezar lo más rápido posible, recomendamos usar Lingo.dev Engine, nuestra propia plataforma alojada que ofrece 10 000 tokens de uso mensual gratuito:
-
Ejecuta el siguiente comando:
npx lingo.dev@latest loginEsto abrirá tu navegador predeterminado y te pedirá que te autentiques.
-
Sigue las instrucciones.
Paso 7. Generar las traducciones
En el directorio que contiene el archivo i18n.json, ejecuta el siguiente comando:
npx lingo.dev@latest run
Este comando:
- Lee el archivo
i18n.json. - Encuentra los archivos que necesitan ser traducidos.
- Extrae el contenido traducible de los archivos.
- Utiliza el LLM configurado para traducir el contenido extraído.
- Escribe el contenido traducido de vuelta en el sistema de archivos.
La primera vez que se generan las traducciones, se crea un archivo i18n.lock. Este archivo realiza un seguimiento del contenido que ha sido traducido, evitando retraducciones innecesarias en ejecuciones posteriores.
Ejemplo
en/example.properties
app.title=MyApp
app.description=A simple demo application
user.greeting=Hello, world!
user.farewell=Thanks for using MyApp
error.message=Something went wrong
error.notFound=Page not found
database.host=localhost
database.port=5432
notification.success=Changes saved!
notification.warning=Please check your input
es/example.properties
app.title=MyApp
app.description=Una aplicación de demostración simple
user.greeting=¡Hola, mundo!
user.farewell=Gracias por usar MyApp
error.message=Algo salió mal
error.notFound=Página no encontrada
database.host=localhost
database.port=5432
notification.success=¡Cambios guardados!
notification.warning=Por favor verifica tu entrada
i18n.json
{
"version": "1.10",
"locale": {
"source": "en",
"targets": ["es"]
},
"buckets": {
"properties": {
"include": ["./[locale]/example.properties"]
}
},
"$schema": "https://lingo.dev/schema/i18n.json"
}
i18n.lock
version: 1
checksums:
2250baa513dddb2c691cb62115d5e257:
app.title: 7dc70110429d46e3685f385bd2cc941c
app.description: e13baa1e885129d9328e216ff534761b
user.greeting: 0468579ef2fbc83c9d520c2f2f1c5059
user.farewell: 118794a2b84f7bfb4b4ce602ed463b0f
error.message: a3cd2f01c073f1f5ff436d4b132d39cf
error.notFound: 97612e6230bc7a1ebd99380bf561b732
database.host: da86e4fc0c04d82c87006dc71cea7e97
notification.success: 3b7a8b0aa23977592d4270ea136a390c
notification.warning: c38895f731311cefacee9e8d7d10fc49