Documentare API
Integrați traducerea puternică în aplicațiile dvs. cu API REST noastră simplă.
Începe
TranslateAPI oferă o simplă interfață REST pentru traducerea textului între 180+ limbi. Toate punctele finale API returnează răspunsurile JSON.
1. Obțineți cheia API
Creați un cont gratuit și generați cheia API de la bordul de bord:
- Inscrie-te la translateapi.ai/signup
- Du-te la Tabel de bord → Keys API
- Faceți clic pe "Creați cheie API" și copiați cheia
Începe cheile API cu ta_ urmat de 56 de caractere hexadecimale.
https://api.translateapi.ai/api/v1/2. Fă-ţi prima cerere
Înlocuiește TU_API_KEY cu cheia din tableau de bord:
curl -X POST https://api.translateapi.ai/api/v1/translate/ \
-H "Content-Type: application/json" \
-H "Authorization: Bearer YOUR_API_KEY" \
-d '{
"text": "Hello, world!",
"target_language": "es"
}'
import requests
response = requests.post(
"https://api.translateapi.ai/api/v1/translate/",
headers={
"Authorization": "Bearer YOUR_API_KEY",
"Content-Type": "application/json"
},
json={
"text": "Hello, world!",
"target_language": "es"
}
)
result = response.json()
print(result["translated_text"]) # "Hola, mundo!"
const response = await fetch("https://api.translateapi.ai/api/v1/translate/", {
method: "POST",
headers: {
"Authorization": "Bearer YOUR_API_KEY",
"Content-Type": "application/json"
},
body: JSON.stringify({
text: "Hello, world!",
target_language: "es"
})
});
const result = await response.json();
console.log(result.translated_text); // "Hola, mundo!"
$ch = curl_init("https://api.translateapi.ai/api/v1/translate/");
curl_setopt_array($ch, [
CURLOPT_RETURNTRANSFER => true,
CURLOPT_POST => true,
CURLOPT_HTTPHEADER => [
"Authorization: Bearer YOUR_API_KEY",
"Content-Type: application/json"
],
CURLOPT_POSTFIELDS => json_encode([
"text" => "Hello, world!",
"target_language" => "es"
])
]);
$result = json_decode(curl_exec($ch), true);
echo $result["translated_text"]; // "Hola, mundo!"
payload := strings.NewReader(`{
"text": "Hello, world!",
"target_language": "es"
}`)
req, _ := http.NewRequest("POST", "https://api.translateapi.ai/api/v1/translate/", payload)
req.Header.Set("Authorization", "Bearer YOUR_API_KEY")
req.Header.Set("Content-Type", "application/json")
resp, _ := http.DefaultClient.Do(req)
defer resp.Body.Close()
var result map[string]interface{}
json.NewDecoder(resp.Body).Decode(&result)
fmt.Println(result["translated_text"]) // "Hola, mundo!"
var client = new HttpClient();
client.DefaultRequestHeaders.Add("Authorization", "Bearer YOUR_API_KEY");
var content = new StringContent(
JsonSerializer.Serialize(new {
text = "Hello, world!",
target_language = "es"
}),
Encoding.UTF8,
"application/json"
);
var response = await client.PostAsync("https://api.translateapi.ai/api/v1/translate/", content);
var result = JsonSerializer.Deserialize<JsonElement>(
await response.Content.ReadAsStringAsync()
);
Console.WriteLine(result.GetProperty("translated_text")); // "Hola, mundo!"
Răspuns
{
"translated_text": "Hola, mundo!",
"source_language": "en",
"target_language": "es",
"translations": {
"es": "Hola, mundo!"
},
"character_count": 13,
"translation_time": 0.45
}
Autentificare
Autentificați cererile folosind o cheie API. Puteți crea cheile API din dvs. tablă de bord.
Autentificare antet (recomandat)
Authorization: Bearer ta_your_api_key_here
Header-ul ApiKey
Authorization: ApiKey ta_your_api_key_here
Parametrul cercetării
https://api.translateapi.ai/api/v1/translate/?api_key=ta_your_api_key_here
Tradu textul
Traduce textul într-un singur limbaj ţintă.
POST https://api.translateapi.ai/api/v1/translate/
Organismul de cerere
| Parametrul | Tip | Necesită | Descriere |
|---|---|---|---|
text |
string | Da. | Text pentru traducere (max 50.000 de caractere) |
target_language |
string | Da. Da. | Target language code (e.g., "es", "fr", "de") |
source_language |
string | Nu. | Source language code. Default: "auto" (auto-detect) |
engine |
string | Nu. | Motorul de traducere: "auto" (defect), "haggingface", sau "madlad". A se vedea modelele de traducere. Modele de traducere. |
* Utilizare target_language (strigă) pentru limba unică sau target_languages (Arătați) pentru multiple. A se vedea Traducere multi- target.
Răspuns
{
"translated_text": "Hola, mundo!",
"source_language": "en",
"target_language": "es",
"translations": {
"es": "Hola, mundo!"
},
"character_count": 13,
"translation_time": 0.45
}
source_language sau să-l pună în "auto" pentru a detecta automat limba sursă. Limba detectată este returnată în source_language Câmpul de răspuns.
Traducere multi- target
Traduceți textul în mai multe limbi într-o singură cerere. Folosește același punct final ca traducere unică.
POST https://api.translateapi.ai/api/v1/translate/
Organismul de cerere
{
"text": "Hello, world!",
"target_languages": ["es", "fr", "de", "ja"],
"source_language": "en"
}
Utilizare target_languages (Array) în loc de target_language (string) pentru obiective multiple.
Răspuns
{
"source_language": "en",
"translations": {
"es": "Hola, mundo!",
"fr": "Bonjour, monde!",
"de": "Hallo, Welt!",
"ja": "こんにちは、世界!"
},
"character_count": 52,
"translation_time": 2.31
}
Traducerea setului
Traduceți mai multe texte deodată cu prelucrarea async. Trimite un lot și sondaj pentru rezultate.
POST https://api.translateapi.ai/api/v1/translate/batch/
Pasul 1: Trimite o serie
curl -X POST https://api.translateapi.ai/api/v1/translate/batch/ \
-H "Authorization: Bearer YOUR_API_KEY" \
-H "Content-Type: application/json" \
-d '{
"texts": ["Hello", "Goodbye", "Thank you"],
"target_language": "es",
"source_language": "en"
}'
Răspuns (HTTP 202 acceptat)
{
"job_id": "67535b2b-c9e3-4f82-9499-e237edbc1dd8",
"status": "pending",
"total_texts": 3,
"queue_position": 1,
"source_language": "en",
"target_languages": ["es"],
"character_count": 22,
"credits_remaining": -1,
"poll_url": "https://api.translateapi.ai/api/v1/jobs/67535b2b-c9e3-4f82-9499-e237edbc1dd8/"
}
Pasul 2: Sondaj pentru rezultate
GET https://api.translateapi.ai/api/v1/jobs/{job_id}/
Exemplu de sondaj (Python)
import time, requests
job_id = response.json()["job_id"]
total = response.json()["total_texts"]
headers = {"Authorization": "Bearer YOUR_API_KEY"}
print(f"Batch submitted: {total} texts (job {job_id})")
while True:
result = requests.get(f"https://api.translateapi.ai/api/v1/jobs/{job_id}/", headers=headers).json()
status = result["status"]
processed = result.get("processed_texts", 0)
progress = result.get("progress_percentage", 0)
if status == "completed":
print(f"Done: {processed}/{total} in {result.get('processing_time', 0):.1f}s")
translations = result["result_data"]["translations"]
break
elif status == "failed":
raise Exception(result.get("error_message", "Translation failed"))
elif status == "pending":
print(f"Queued (position {result.get('queue_position', '?')})")
else:
print(f"[{status}] {processed}/{total} ({progress:.0f}%)")
time.sleep(3)
Răspuns (completat)
{
"job_id": "67535b2b-...",
"status": "completed",
"processed_texts": 3,
"total_texts": 3,
"progress_percentage": 100.0,
"processing_time": 10.65,
"result_data": {
"translations": ["Hola", "Adiós", "Gracias"],
"source_language": "en",
"target_language": "es",
"character_count": 22,
"processing_time": 10.65
}
}
Urmărirea progresului în timp real
| Câmp | Descriere |
|---|---|
status |
pending (în filare, în aşteptare pentru un lucrător GPU), processing (traducere activă), completed, failed |
processed_texts |
Numărul de traduceri individuale finalizate până acum. Actualizări în timp real ca fiecare text este tradus. |
progress_percentage |
Procentul de completare (0-100). Calculat din text_ prelucrat / text_ total. |
queue_position |
Poziția ta în coada atunci când starea este "pentru" (1 = următoarea). Null la prelucrarea sau finalizarea. Folosește acest lucru pentru a estima timpul de așteptare și afișează starea coada utilizatorilor. |
processing_time |
Timpul total de prelucrare în secunde (disponibil după finalizare). |
Serie multi- limbi
Traduceti mai multe texte la mai multe limbi de o dată:
{
"texts": ["Hello", "Goodbye"],
"target_languages": ["es", "fr"],
"source_language": "en"
}
Date_ rezultate_ completate
{
"translations": [
{"es": "Hola", "fr": "Bonjour"},
{"es": "Adiós", "fr": "Au revoir"}
],
"source_language": "en",
"target_languages": ["es", "fr"],
"character_count": 24,
"processing_time": 2.45
}
Parametrii solicitării
| Parametrul | Tip | Necesită | Descriere |
|---|---|---|---|
texts |
array | Da. | Array de stringuri de traducere |
target_language |
string | Da. Da. | Codul limbii ţintă pentru limba unică |
target_languages |
array | Da. Da. | Retragerea codurilor limbii ţintă pentru mai multe limbi |
source_language |
string | Nu. | Source language code. Default: "auto" |
* Asigurați fie target_language sau target_languages, nu amândoi.
Cele mai bune practici pentru sarcini de lucru mari
- Trimite 1 limba țintă pe cerere de lot. Acest lucru menține fiecare lot rapid și face progrese ușor de urmărit.
- Păstrați loturi la 50-100 de texte. Loturi mai mici completă mai repede și vă oferă mai frecvente actualizări de progres.
- Transmiteți cât mai multe locuri de muncă pe lot de care aveți nevoie — scalele noastre GPU cluster auto pentru a gestiona cererea. Joburile sunt prelucrate în paralel în mai multe cazuri.
- La timp, re-poll același job_id în loc de a trimite un lot nou. Angajamentul original poate fi încă prelucrat pe GPU.
- Sondaj la fiecare 3-5 secunde.
Traducerea documentului
Traducerea completă a documentelor în timp ce menținerea formatului. Suportează mai multe formate de fișiere.
POST https://api.translateapi.ai/api/v1/translate/document/
Cerere (multipart/form-data)
| Parametrul | Tip | Necesită | Descriere |
|---|---|---|---|
file |
file | Da. | Documentul de traducere (max 10MB) |
target_language |
string | Da. | Target language code (e.g., "es", "fr", "de") |
source_language |
string | Nu. | Source language code. Default: "auto" (auto-detect) |
Tipuri de fișiere suportate
Documente
.txt- Fișiere text simplu.docx- Documente cu cuvinte.pdf- Documente PDF (inclusiv scanate)
Date și localizare
.json- Fișiere JSON (traduce valorile stringilor).xml- Fișiere XML.srt- Fișiere de subtitrare.po/.pot- Fișiere de traducere Gettext
Imagini (OCR)
.jpg/.jpeg- Imagini JPEG (OCR).png- Imagini PNG (OCR).tiff/.tif- Imagini TIFF (OCR).bmp- Imagini BMP (OCR).webp- Imagini WebP (OCR)
Exemplu (cURL)
# Translate a Word document
curl -X POST https://api.translateapi.ai/api/v1/translate/document/ \
-H "Authorization: Bearer YOUR_API_KEY" \
-F "file=@document.docx" \
-F "target_language=es" \
-F "source_language=en"
# Translate text from an image (OCR)
curl -X POST https://api.translateapi.ai/api/v1/translate/document/ \
-H "Authorization: Bearer YOUR_API_KEY" \
-F "file=@scanned_page.jpg" \
-F "target_language=es" \
-F "source_language=en"
Răspuns
{
"id": 123,
"original_filename": "document.docx",
"file_type": "docx",
"source_language": "en",
"target_language": "es",
"status": "completed",
"character_count": 5420,
"translated_file_url": "/media/translated/document_es.docx",
"created_at": "2024-01-15T10:30:00Z",
"completed_at": "2024-01-15T10:30:05Z"
}
GET https://api.translateapi.ai/api/v1/translate/document/{id}/
Verificați starea traducerii unui document sau recuperați URL-ul descărcat.
Valori statutului
pending |
Fișier încărcat, în așteptare pentru a fi procesat |
processing |
Traducerea în curs |
completed |
Traducere completă, descărcare disponibilă |
failed |
Traducerea a eșuat (check error_message) |
Limbi sprijinite
Obține lista tuturor limbilor susținute.
GET https://api.translateapi.ai/api/v1/translate/languages/
Răspuns
{
"count": 186,
"results": [
{"iso": "en", "name": "English", "en_label": "English"},
{"iso": "es", "name": "Español", "en_label": "Spanish"},
{"iso": "fr", "name": "Français", "en_label": "French"},
...
]
}
Modele de traducere
Folosim modele de traducere open source de ultima generație care funcționează pe propria infrastructură GPU. Toate modelele sunt comercial licențiate (Apache 2.0).
| Model | Limbi | Cel mai bun pentru |
|---|---|---|
| Helsinki-NLP/opus-mt | 50+ perechi de limbaj | Limbi comune (EN, ES, FR, DE, IT, PT, RU, ZH, JA, etc.) |
| Google MADLAD-400 | Peste 400 de limbi | Limbi rare, acoperire cuprinzătoare |
API selectează automat cel mai bun model pentru perechea de limbi. Puteți specifica un engine parametri:
| Motor | Descriere |
|---|---|
"auto" |
Predefinit. Tria HuggingFace primul, cade înapoi la MADLAD-400 |
"huggingface" |
Forța HuggingFace/MarianMT (mai rapid, 50+ limbi) |
"madlad" |
Forța MADLAD-400 (400+ limbi) |
Eroare de manipulare
API utilizează coduri de stare HTTP standard pentru a indica succes sau eșec.
| Codul | Descriere |
|---|---|
| 200 | Succes |
| 202 | Acceptat — Lotul de locuri de muncă în coada cu succes |
| 400 | Cerere necorespunzătoare — parametri nevalizi (nu există text, limbaj nesuportat, etc.) |
| 401 | Neautorizat - Cheia API nevalidă sau lipsă |
| 402 | Plata necesara — Creditii de caractere epuizate. Upgradeaz-va planul sau achizitioneaza un top-up. |
| 403 | Interzis – cheia API lipsește domeniul de aplicare necesar sau IP nu în lista albă |
| 503 | Serviciu Nedisponibil - motor de traducere temporar în jos |
Format de răspuns la eroare
{
"error": "insufficient_credits",
"credits_remaining": 0
}
Limitele de utilizare
TranslateAPI has no request rate limits. All requests are queued and processed by our auto-scaling GPU cluster. Your plan determines your monthly character allowance:
| Plan | Personaje/Luna | API de lot | Documente | Preț | |
|---|---|---|---|---|---|
| Gratuit | 250,000 | — | — | $0 | Inscrie-te gratis |
| Pornitor | 2,500,000 | $9/mo | Subscriere | ||
| Pro | 10,000,000 | $29/mo | Subscriere | ||
| Afaceri | 40,000,000 | $79/mo | Subscriere | ||
| Scala | 125,000,000 | $199/mo | Subscriere | ||
| Enterprise | Unlimited | $499/mo | Contact Sales |
Când depăşeşti limita, vei primi o 402 Payment Required Răspuns până la luna următoare sau upgradezi.
Infrastructura Cloud de scară automată
TranslateAPI se execută pe instanțele NVIDIA A100 GPU dedicate cu scalare orizontală automată. Când cererea crește, cazurile GPU suplimentare sunt lansate în câteva minute pentru a menține timpurile de răspuns rapid. Toate cererile sunt prelucrate și în coada — trimite sute de cereri concomitente și vor fi toate gestionate. traduceri în timp real obțin prioritate, procesul loturii de muncă în fundal.
Ai nevoie de mai multe credite?
Achiziționează un top-up de credit de o dată fără a schimba planul. Afișează ambalajele de top- up