API-documentatie

Integreer krachtige vertaling in uw toepassingen met onze eenvoudige REST API.

Starten

De TranslateAPI biedt een eenvoudige REST-interface voor het vertalen van tekst tussen 180+ talen. Alle API-eindpunten geven JSON-responsen terug.

1. Haal uw API-sleutel

Maak een gratis account aan en maak uw API-sleutel vanaf het dashboard:

  1. Aanmelden bij translateapi.ai/signup
  2. Ga naar Dashboard → API-sleutels
  3. Klik op "Create API Key" en kopieer uw sleutel

API-toetsen beginnen met ta_ gevolgd door 56 hex personages.

Basis-URL: https://api.translateapi.ai/api/v1/
2. Maak uw eerste verzoek

Vervang UW_API_KEY door de sleutel van uw dashboard:

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!"
Respons
{
    "translated_text": "Hola, mundo!",
    "source_language": "en",
    "target_language": "es",
    "translations": {
        "es": "Hola, mundo!"
    },
    "character_count": 13,
    "translation_time": 0.45
}

Authenticatie

Authenticeer uw verzoeken met behulp van een API-sleutel. U kunt API-sleutels aanmaken vanuit uw dashboard.

Kop-authenticatie (aanbevolen)
Authorization: Bearer ta_your_api_key_here
ApiKey-header
Authorization: ApiKey ta_your_api_key_here
Zoekparameter
https://api.translateapi.ai/api/v1/translate/?api_key=ta_your_api_key_here
Houd uw API sleutels veilig! Laat ze niet onthullen in client-side code of openbare repositories.

Tekst vertalen

Vertaal tekst naar één doeltaal.

POST https://api.translateapi.ai/api/v1/translate/
Verzoek om een instantie
Parameter Type Vereist Omschrijving
text string Ja. Tekst om te vertalen (max 50.000 tekens)
target_language string Ja* Target language code (e.g., "es", "fr", "de")
source_language string Nee Source language code. Default: "auto" (auto-detect)
engine string Nee Vertaalmachine: "auto" (standaard), "knuffelkop" of "madlad." Zie Vertaalmodellen. Vertaalmodellen.

* Gebruik target_language (tekenreeks) voor één taal of target_languages (array) voor meerdere. Zie Multi-Target-vertaling.

Respons
{
    "translated_text": "Hola, mundo!",
    "source_language": "en",
    "target_language": "es",
    "translations": {
        "es": "Hola, mundo!"
    },
    "character_count": 13,
    "translation_time": 0.45
}
Autodetectie: Omit source_language of zet het op "auto" om de brontaal automatisch op te sporen. De gedetecteerde taal wordt teruggestuurd in de source_language responsveld.

Multi-Target-vertaling

Vertaal tekst naar meerdere talen in één verzoek. Gebruikt hetzelfde eindpunt als enkele vertaling.

POST https://api.translateapi.ai/api/v1/translate/
Verzoek om een instantie
{
    "text": "Hello, world!",
    "target_languages": ["es", "fr", "de", "ja"],
    "source_language": "en"
}

Gebruik target_languages (array) in plaats van target_language (string) voor meerdere doelen.

Respons
{
    "source_language": "en",
    "translations": {
        "es": "Hola, mundo!",
        "fr": "Bonjour, monde!",
        "de": "Hallo, Welt!",
        "ja": "こんにちは、世界!"
    },
    "character_count": 52,
    "translation_time": 2.31
}
Tip: U kunt vertalen naar maximaal 50 talen in een enkele aanvraag.

Batchvertaling

Vertaal meerdere teksten tegelijk met async verwerking. Stuur een batch en poll voor resultaten.

Grenswaarden: Max. 100 teksten per batch, max. 300 items in totaal (teksten × doeltalen). Jobs time-out 45 minuten na het starten van de verwerking.
Snelheid: Gemeenschappelijke talen (ES, FR, DE) maken gebruik van snelle modellen (~0.1s/text). Minder gangbare talen maken gebruik van ons meertalige model (~1-3s/text).
POST https://api.translateapi.ai/api/v1/translate/batch/
Stap 1: Submit Batch
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"
}'
Respons (HTTP 202 aanvaard)
{
    "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/"
}
Stap 2: Bespreking van de resultaten
GET https://api.translateapi.ai/api/v1/jobs/{job_id}/
Polling Example (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)
Respons (voltooid)
{
    "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
    }
}
Real-Time Progress Tracking
Veld Omschrijving
status pending (wachtend op een GPU werknemer), processing (actief vertalen), completed, failed
processed_texts Aantal individuele vertalingen voltooid tot nu toe. Updates in real time zoals elke tekst wordt vertaald.
progress_percentage Afrondingspercentage (0-100). Berekend vanuit verwerkt_teksten / total_texts.
queue_position Uw positie in de wachtrij wanneer de status "door" (1 = volgende up) is. Null bij het verwerken of voltooien. Gebruik dit om de wachttijd te schatten en de wachtrijstatus aan uw gebruikers te tonen.
processing_time [Error: UNIQUE constraint failed: translations_translation.textbase_id, translations_translation.language_id]
Partij met meerdere talen

Vertaal meerdere teksten in meerdere talen tegelijk:

{
    "texts": ["Hello", "Goodbye"],
    "target_languages": ["es", "fr"],
    "source_language": "en"
}
Resultaten_gegevens voltooid
{
    "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
}
Parameters aanvragen
Parameter Type Vereist Omschrijving
texts array Ja. Array of strings to translate
target_language string Ja* Doeltaalcode voor één taal
target_languages array Ja* Array of target language codes for multiple languages
source_language string Nee Source language code. Default: "auto"

* Zorg ervoor dat ofwel target_language of target_languagesNiet allebei.

[Error: UNIQUE constraint failed: translations_translation.textbase_id, translations_translation.language_id]
  • Verstuur 1 doeltaal per batch verzoek. Dit houdt elke batch snel en maakt vooruitgang gemakkelijk te volgen.
  • [Error: UNIQUE constraint failed: translations_translation.textbase_id, translations_translation.language_id]
  • Zoveel batch-taken als u nodig hebt indienen onze GPU-cluster auto-schalen om de vraag te behandelen. Jobs worden parallel verwerkt in meerdere gevallen.
  • [Error: UNIQUE constraint failed: translations_translation.textbase_id, translations_translation.language_id]
  • Bekijk elke 3-5 seconden. Meer frequente peiling versnelt de verwerking niet.

Documentvertaling

Vertaal volledige documenten met behoud van formatteren. Ondersteunt meerdere bestandsformaten.

POST https://api.translateapi.ai/api/v1/translate/document/
Verzoek (multipartiete/vormgegevens)
Parameter Type Vereist Omschrijving
file file Ja. Het te vertalen document (max 10MB)
target_language string Ja. Target language code (e.g., "es", "fr", "de")
source_language string Nee Source language code. Default: "auto" (auto-detect)
Ondersteunde bestandstypen
Documenten
  • .txt - Platte tekstbestanden
  • .docx - Word-documenten
  • .pdf - PDF-documenten (inclusief gescand)
Gegevens & lokalisatie
  • .json - JSON-bestanden (vertaalt tekenreekswaarden)
  • .xml - XML-bestanden
  • .srt - Bestanden met ondertiteling
  • .po / .pot - Tekstvertalingsbestanden ophalen
Afbeeldingen (OCR)
  • .jpg / .jpeg - JPEG-afbeeldingen (OCR)
  • .png - PNG-afbeeldingen (OCR)
  • .tiff / .tif - TIFF-afbeeldingen (OCR)
  • .bmp - BMP-afbeeldingen (OCR)
  • .webp - WebP-afbeeldingen (OCR)
Voorbeeld (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"
Respons
{
    "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"
}
OCR-ondersteuning: Afbeeldingsbestanden en gescande PDF's worden verwerkt met optische karakterherkenning (OCR) om tekst te extraheren voor vertaling. Voor de beste resultaten, gebruik duidelijke, hoge resolutie beelden.
GET https://api.translateapi.ai/api/v1/translate/document/{id}/

Controleer de status van een documentvertaling of download de URL.

Statuswaarden
pending Bestand geüpload, wachtend om te worden verwerkt
processing Vertaling in uitvoering
completed Vertaling voltooid, download beschikbaar
failed Vertaling mislukt (check error_message)

Ondersteunde talen

Krijg de lijst van alle ondersteunde talen.

GET https://api.translateapi.ai/api/v1/translate/languages/
Respons
{
    "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"},
        ...
    ]
}

Bekijk alle 186 talen

Vertaalmodellen

We maken gebruik van state-of-the-art open source vertaalmodellen die draaien op onze eigen GPU infrastructuur. Alle modellen zijn commercieel gelicentieerd (Apache 2.0).

Model Talen Beste voor
Helsinki-NLP/opus-mt 50+ taalparen Gemeenschappelijke talen (EN, ES, FR, DE, IT, PT, RU, ZH, JA, enz.)
Google MADLAD-400 400+ talen Zeldzame talen, uitgebreide dekking

De API selecteert automatisch het beste model voor uw taalpaar. U kunt optioneel een engine parameter:

Motor Omschrijving
"auto" Standaard. Probeert HuggingFace eerst, valt terug naar MADLAD-400
"huggingface" Forceer HuggingFace/MarianMT (snelste, 50+ talen)
"madlad" Dwing MADLAD-400 (400+ talen)

Fout bij omgaan

De API gebruikt standaard HTTP-statuscodes om succes of mislukking aan te geven.

Rubriek Omschrijving
200 Succes
202 Geaccepteerd in de wachtrij "Batch'-taak succesvol
400 Ongeldige parameters (ontbrekende tekst, niet-ondersteunde taal, enz.)
401 Ongeautoriseerd - Ongeldige of ontbrekende API-sleutel
402 Betaling Vereist.. Karakterpunten uitgeput. Upgrade uw plan of aankoop van een up-up.
403 Verboden API sleutel ontbreekt vereiste scope of IP niet in de whitelist
503 Service niet beschikbaar - Vertaalmachine tijdelijk uit
Fout in antwoordformaat
{
    "error": "insufficient_credits",
    "credits_remaining": 0
}

Gebruikslimieten

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 Tekens/Maand Lot API Documenten Prijs
Vrij 250,000 $0 Gratis aanmelden
Starter 2,500,000 $9/munit description in lists Abonneren
Pro 10,000,000 $29/munit description in lists Abonneren
Zaken 40,000,000 $79/munit description in lists Abonneren
Schaal 125,000,000 $199/munit description in lists Abonneren
Enterprise Unlimited $499/munit description in lists Contact Sales

Wanneer u uw limiet overschrijdt, ontvangt u een 402 Payment Required antwoord tot de volgende maand of je upgrade.

Cloud-infrastructuur automatisch schalen

TranslateAPI draait op dedicated NVIDIA A100 GPU gevallen met automatische horizontale schaalvergroting. Wanneer de vraag toeneemt, extra GPU gevallen worden gelanceerd binnen enkele minuten om snelle responstijden te handhaven. Alle verzoeken worden in de wachtrij geplaatst en verwerkt. Stuur honderden gelijktijdige verzoeken en ze zullen allemaal worden behandeld. Real-time vertalingen krijgen prioriteit, batch banen proces op de achtergrond.

Meer krediet nodig?

Halverwege de maand zonder karakters? Koop een eenmalige credit-up zonder uw plan te wijzigen. Bekijk top-up packs

Beoordeel deze pagina
Bedankt voor je beoordeling!
/5 gebaseerd op ratings