Dokumentasi API

Integrate kuat terjemahan ke aplikasi Anda dengan API REST sederhana kami.

Mulai

TerjemahanAPI menyediakan antarmuka sederhana untuk menerjemahkan teks antara 180+ bahasa. Semua titik akhir API membalas respon JSON.

1. Dapatkan Kunci API Anda

Buat akun bebas dan hasilkan kunci API Anda dari dashboard:

  1. Daftar di translateapi.ai/signup
  2. Ke Dasbor → Tombol API
  3. Klik "Buat Kunci API" dan salin kunci Anda

Tombol API dimulai dengan ta_ diikuti oleh 56 karakter hex.

URL Dasar: https://api.translateapi.ai/api/v1/
Buatlah Permintaan Pertama Anda

Ganti K_API_KI ANDA dengan kunci dari dashboard Anda:

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

Otentikasi

Otentikasi permintaan Anda memakai kunci API. Anda dapat membuat kunci API dari Anda dashboard.

Otentikasi Header (Disarankan)
Authorization: Bearer ta_your_api_key_here
ApiKey Header
Authorization: ApiKey ta_your_api_key_here
Parameter Query
https://api.translateapi.ai/api/v1/translate/?api_key=ta_your_api_key_here
Jaga kunci API Anda tetap aman! Jangan mengekspos mereka dalam kode sisi klien atau repositori publik.

Terjemahkan Teks

Terjemahkan teks ke bahasa target tunggal.

POST https://api.translateapi.ai/api/v1/translate/
Badan Permintaan
Parameter Tipe Diperlukan Deskripsi
text string Ya Teks untuk diterjemahkan (maksimal 50.000 karakter)
target_language string Ya * Target language code (e.g., "es", "fr", "de")
source_language string Tidak Source language code. Default: "auto" (auto-detect)
engine string Tidak Mesin terjemahan: "auto" (baku), "huggingface" (wajah berjuluk), atau "madlad). Lihat Model Penerjemahan. Model Penerjemahan.

* Gunakan target_language (string) untuk bahasa tunggal atau target_languages (array) untuk beberapa. lihat Terjemahan Multi-Target.

Tanggapan
{
    "translated_text": "Hola, mundo!",
    "source_language": "en",
    "target_language": "es",
    "translations": {
        "es": "Hola, mundo!"
    },
    "character_count": 13,
    "translation_time": 0.45
}
Deteksi-otomatis: Omit source_language atau set ke "auto" untuk mendeteksi secara otomatis bahasa sumber. Bahasa yang terdeteksi dikembalikan dalam source_language lapangan respon.

Terjemahan Multi-Target

Terjemahkan teks ke berbagai bahasa dalam satu permintaan. Gunakan titik akhir yang sama dengan terjemahan tunggal.

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

Gunakan target_languages (array) bukan target_language (string) untuk beberapa target.

Tanggapan
{
    "source_language": "en",
    "translations": {
        "es": "Hola, mundo!",
        "fr": "Bonjour, monde!",
        "de": "Hallo, Welt!",
        "ja": "こんにちは、世界!"
    },
    "character_count": 52,
    "translation_time": 2.31
}
Tip: Anda dapat menerjemahkan hingga 50 bahasa dalam satu permintaan.

Terjemahan Batch

Terjemahkan beberapa teks sekaligus dengan pemrosesan sinkronisasi. Kirim batch dan jajak pendapat untuk hasil.

Batas: Max 100 teks per batch, maksimal 300 item (teks × target bahasa). Waktu kerja keluar 45 menit setelah pemrosesan dimulai.
Kecepatan: Bahasa umum (ES, FR, DE) menggunakan model cepat (~0,1s/text). Bahasa yang kurang umum menggunakan model multibahasa kita (~1-3s/text).
POST https://api.translateapi.ai/api/v1/translate/batch/
Langkah 1: Masukkan 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"
}'
Tanggapan (HTTP 202 Diterima)
{
    "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/"
}
Langkah 2: Poll untuk Hasil
GET https://api.translateapi.ai/api/v1/jobs/{job_id}/
Contoh Polling (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)
Respon (selesai)
{
    "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
    }
}
Pelacakan Progres Real-Time
Ruas Deskripsi
status pending (queued, menunggu pekerja GPU), processing (secara aktif menerjemahkan), completed, failed
processed_texts Jumlah terjemahan individu yang selesai sejauh ini. Pemutakhiran secara real time ketika setiap teks diterjemahkan.
progress_percentage Persentase pelengkapan (0-100). Dihitung dari proses_teks / total_texts.
queue_position Posisi Anda di antrian ketika status "pending" (1 = selanjutnya). Null ketika memproses atau menyelesaikan. Gunakan ini untuk memperkirakan waktu tunggu dan tampilkan status antrian ke pengguna Anda.
processing_time Total waktu pemrosesan dalam detik (tersedia ketika selesai).
Batch Multi-Bahasa

Terjemahkan beberapa teks ke berbagai bahasa sekaligus:

{
    "texts": ["Hello", "Goodbye"],
    "target_languages": ["es", "fr"],
    "source_language": "en"
}
Hasil_data selesai
{
    "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
}
Parameter Permintaan
Parameter Tipe Diperlukan Deskripsi
texts array Ya Array string untuk menerjemahkan
target_language string Ya * Target kode bahasa untuk bahasa tunggal
target_languages array Ya * Array dari kode bahasa target untuk berbagai bahasa
source_language string Tidak Source language code. Default: "auto"

* Berikan baik target_language atau target_languagesBukan keduanya.

Praktek Terbaik bagi Beban Kerja Besar
  • Kirim 1 bahasa target per permintaan batch. Hal ini membuat setiap batch cepat dan membuat kemajuan mudah untuk dilacak.
  • Simpan batch pada 50-100 teks. batch lebih kecil lengkap lebih cepat dan memberikan Anda lebih sering update kemajuan.
  • Kirim sebanyak yang Anda butuhkan dari kelompok GPU kami untuk menangani permintaan. Pekerjaan diproses secara paralel dalam beberapa contoh.
  • Pada waktu habis, kembali-poll pekerjaan yang sama_id bukan mengirimkan batch baru. Pekerjaan asli mungkin masih diproses di GPU.
  • Lebih sering polling tidak mempercepat pemrosesan.

Terjemahan Dokumen

Terjemahkan seluruh dokumen saat melestarikan format. Mendukung beberapa format berkas.

POST https://api.translateapi.ai/api/v1/translate/document/
Permintaan (multipart/form-data)
Parameter Tipe Diperlukan Deskripsi
file file Ya Dokumen untuk diterjemahkan (max 10MB)
target_language string Ya Target language code (e.g., "es", "fr", "de")
source_language string Tidak Source language code. Default: "auto" (auto-detect)
Tipe Berkas Yang Didukung
Dokumen
  • .txt - Berkas teks biasa
  • .docx - Dokumen Word
  • .pdf - Dokumen PDF (termasuk pemindaian)
Data & Lokalisasi
  • .json - Berkas JSON (menterjemahkan nilai string)
  • .xml - Berkas XML
  • .srt - Berkas subjudul
  • .po / .pot - Berkas terjemahan Gettext
Gambar (OCR)
  • .jpg / .jpeg - Gambar JPEG (OCR)
  • .png - Gambar PNG (OCR)
  • .tiff / .tif - Citra TIFF (OCR)
  • .bmp - Gambar BMP (OCR)
  • .webp - Citra WebP (OCR)
Contoh (kurl)
# 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"
Tanggapan
{
    "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"
}
Dukungan OCR: Berkas gambar dan dipindai PDF diproses dengan pengenalan karakter optik (OCR) untuk mengekstrak teks sebelum terjemahan. Untuk hasil terbaik, gunakan gambar resolusi tinggi yang jelas.
GET https://api.translateapi.ai/api/v1/translate/document/{id}/

Periksa status dari sebuah terjemahan dokumen atau ambil kembali URL unduhan.

Nilai Status
pending Berkas diunggah, menunggu diproses
processing Penerjemahan sedang berlangsung
completed Terjemahan selesai, download tersedia
failed Terjemahan gagal (check error_message)

Bahasa yang Didukung

Dapatkan daftar semua bahasa yang didukung.

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

Lihat Semua 186 Bahasa

Model Penerjemahan

Kami menggunakan model terjemahan open source yang canggih yang berjalan pada infrastruktur GPU kami sendiri. Semua model dilisensikan secara komersial (Apache 2.0).

Model Bahasa Terbaik Untuk
Helsinki-NLP/opus-mt 50+ pasangan bahasa Bahasa umum (EN, ES, FR, DE, IT, PT, RUS, ZH, JA, dsb.)
Google MADLAD-400 400+ bahasa Bahasa langka, cakupan komprehensif

API secara otomatis memilih model terbaik bagi pasangan bahasa Anda. Anda dapat menentukan secara opsional engine parameter:

Mesin Deskripsi
"auto" Tries HuggingFace pertama, jatuh kembali ke MADLAD-400
"huggingface" Force Huggingface/MarianMT (paling cepat, 50 bahasa+)
"madlad" Force MADLAD-400 (400+ bahasa)

Kesalahan Menangani

API menggunakan kode status HTTP standar untuk mengindikasikan sukses atau gagal.

Kode Deskripsi
200 Berhasil
202 Menerima pekerjaan Batch sukses antrian
400 Permintaan ❑ Parameter salah (teks hilang, bahasa yang tidak didukung, dsb.)
401 Tak berwenang - Kunci API tak valid atau hilang
402 Pembayaran Memerlukan kredit karakter habis, Meningkatkan rencana Anda atau membeli top-up.
403 Kunci API terlarang kurang lingkup yang diperlukan atau IP tidak dalam daftar putih
503 Layanan mesin Terjemahan untuk sementara tidak tersedia
Format Respon Galat
{
    "error": "insufficient_credits",
    "credits_remaining": 0
}

Batas Penggunaan

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:

Rencana Karakter/Bulan API Batch Dokumen Harga
Bebas 250,000 $0 Daftar Bebas
Pemulai 2,500,000 $9/mo Berlangganan
Pro 10,000,000 $29/mo Berlangganan
Bisnis 40,000,000 $79/mo Berlangganan
Skala 125,000,000 $199/mo Berlangganan
Enterprise Unlimited $499/mo Contact Sales

Ketika Anda melampaui batas Anda, Anda akan menerima 402 Payment Required respon sampai bulan depan atau Anda upgrade.

Infrastruktur Awan Skala Otomatis

TerjemahkanAPI berjalan pada NVIDIA A100 GPU instansi dengan skala horizontal otomatis. Ketika permintaan meningkat, tambahan GPU instansi diluncurkan dalam hitungan menit untuk mempertahankan waktu respon cepat. Semua permintaan diantri dan diproses mengirimkan ratusan permintaan bersamaan dan mereka semua akan ditangani. Terjemahan real-time mendapatkan prioritas, proses batch job di latar belakang.

Perlu Lebih Banyak Kredit?

Membeli kredit satu kali top-up tanpa mengubah rencana Anda. Lihat paket top-up

Laju halaman ini
Terima kasih atas ratingmu!
/5 berdasarkan peringkat