Dokumentimi i API
Integro përkthimet e fuqishme në aplikacionet tuaja me API-në tonë të thjeshtë REST.
Duke filluar
TranslateAPI ofron një ndërfaqe të thjeshtë REST për përkthimin e tekstit midis më shumë se 180 gjuhëve. Të gjitha pikat përfundimtare të API kthejnë përgjigje JSON.
1. Merr çelësin tënd API
Krijo një profil të lirë dhe gjenero çelësin tënd të API nga paneli i kontrollit:
- Regjistrohu tek translateapi.ai/signup
- Shko tek Paneli i Kontrollit → Kyçet e API
- Kliko "Krij çelësin e API" dhe kopjo çelësin tënd
Kyçet e API fillojnë me ta_ e ndjekur nga 56 karaktere heksadecimale.
https://api.translateapi.ai/api/v1/2. Bëj kërkesën tënde të parë
Zëvendëso YOUR_API_KEY me kyçin nga paneli juaj:
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!"
Përgjigje
{
"translated_text": "Hola, mundo!",
"source_language": "en",
"target_language": "es",
"translations": {
"es": "Hola, mundo!"
},
"character_count": 13,
"translation_time": 0.45
}
Autentifikim
Autentiko kërkesat tuaja duke përdorur një kyç API. Mund të krijoni kyçe API nga dashboard.
Header Authentication (Recommended)
Authorization: Bearer ta_your_api_key_here
ApiKey Header
Authorization: ApiKey ta_your_api_key_here
Parametri i kërkimit
https://api.translateapi.ai/api/v1/translate/?api_key=ta_your_api_key_here
Përkthe tekstin
Përkthe tekstin në një gjuhë të vetme.
POST https://api.translateapi.ai/api/v1/translate/
Korpi i kërkesës
| Parametrat | Lloji | E nevojshme | Përshkrimi |
|---|---|---|---|
text |
string | Po. | Teksti për t'u përkthyer (maksimum 50,000 karakterë) |
target_language |
string | Po. | Target language code (e.g., "es", "fr", "de") |
source_language |
string | Jo. | Source language code. Default: "auto" (auto-detect) |
engine |
string | Jo. | Motori i përkthimit: "auto" (i prezgjedhur), "huggingface", ose "madlad". Shiko Modelet e Përkthimit. Modele përkthimi. |
* Përdorimi target_language (string) për gjuhë të vetme ose target_languages (array) për shumëfish. Shiko Përkthim shumë-objektivësh.
Përgjigje
{
"translated_text": "Hola, mundo!",
"source_language": "en",
"target_language": "es",
"translations": {
"es": "Hola, mundo!"
},
"character_count": 13,
"translation_time": 0.45
}
source_language ose vendosje në "auto" për të zbuluar automatikisht gjuhën e burimit. Gjuha e zbuluar kthehet në source_language fushë përgjigje.
Përkthim shumë-objektivësh
Përkthe tekstin në gjuhë të shumta në një kërkesë të vetme. Përdor të njëjtin përfundim si përkthimi i vetëm.
POST https://api.translateapi.ai/api/v1/translate/
Korpi i kërkesës
{
"text": "Hello, world!",
"target_languages": ["es", "fr", "de", "ja"],
"source_language": "en"
}
Përdorimi target_languages (array) në vend të target_language (string) për objektiva të shumta.
Përgjigje
{
"source_language": "en",
"translations": {
"es": "Hola, mundo!",
"fr": "Bonjour, monde!",
"de": "Hallo, Welt!",
"ja": "こんにちは、世界!"
},
"character_count": 52,
"translation_time": 2.31
}
Përkthimi i grupit
Përkthe tekste të shumta në të njëjtën kohë me përpunimin asinkron. Dërgo një grup dhe pyet për rezultate.
POST https://api.translateapi.ai/api/v1/translate/batch/
Hapi 1: dërgo grupin
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"
}'
Përgjigja (HTTP 202 e pranuar)
{
"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/"
}
Hapi 2: Sondazh për rezultatet
GET https://api.translateapi.ai/api/v1/jobs/{job_id}/
Shembull Poll (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)
Përgjigje (e plotësuar)
{
"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
}
}
Gjurmimi i përparimit në kohë reale
| Fusha | Përshkrimi |
|---|---|
status |
pending [Error: UNIQUE constraint failed: translations_translation.textbase_id, translations_translation.language_id] processing (aktivisht duke përkthyer), completed[Error: UNIQUE constraint failed: translations_translation.textbase_id, translations_translation.language_id] failed |
processed_texts |
Numri i përkthimeve individuale të plotësuara deri tani. Përditësohet në kohë reale ndërsa përkthehet çdo tekst. |
progress_percentage |
Përqindja e kompletimit (0-100). llogaritur nga processed_texts / total_texts. |
queue_position |
Pozicioni juaj në radhë kur gjendja është "në pritje" (1 = e ardhmja). Null kur përpunimi është përfunduar. Përdor këtë për të llogaritur kohën e pritjes dhe për t'u treguar përdoruesve tuaj gjendjen e radhës. |
processing_time |
[Error: UNIQUE constraint failed: translations_translation.textbase_id, translations_translation.language_id] |
Grup shumëgjuhësh
Përkthe disa tekste në disa gjuhë në të njëjtën kohë:
{
"texts": ["Hello", "Goodbye"],
"target_languages": ["es", "fr"],
"source_language": "en"
}
Rezultati i plotësuar i të dhënave
{
"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
}
Parametrat e kërkesës
| Parametrat | Lloji | E nevojshme | Përshkrimi |
|---|---|---|---|
texts |
array | Po. | Array me stringa për t'u përkthyer |
target_language |
string | Po. | Kodi i gjuhës së synuar për një gjuhë të vetme |
target_languages |
array | Po. | Kodet e gjuhës së synuar për gjuhë të shumta |
source_language |
string | Jo. | Source language code. Default: "auto" |
* Shkruaj ose target_language ose target_languagesJo të dyja.
Praktikat më të mira për ngarkimet e mëdha të punës
- [Error: UNIQUE constraint failed: translations_translation.textbase_id, translations_translation.language_id]
- Mbaj grupet në 50-100 tekste. Grupet më të vogla përfundojnë më shpejt dhe të japin përditësime më të shpeshta të përparimit.
- Paraqitja e sa më shumë punëve të grupit sa të duash - grupi ynë i GPU-ve auto-shkallon për të trajtuar kërkesat. Punët përpunuhen në paralel në instanca të shumta.
- Në fund të kohës së caktuar, kërko përsëri të njëjtin job_id në vend që të dërgosh një grup të ri. Puna origjinale mund të jetë ende duke u përpunuar në GPU.
- Sondazh çdo 3-5 sekonda. Sondazhi më i shpeshtë nuk e shpejton përpunimin.
Përkthimi i dokumentit
Përkthe të gjithë dokumentët duke ruajtur formatimin. Suporton formate të shumta file.
POST https://api.translateapi.ai/api/v1/translate/document/
Kërkesë (multipart/form-data)
| Parametrat | Lloji | E nevojshme | Përshkrimi |
|---|---|---|---|
file |
file | Po. | Dokumenti për t'u përkthyer (max 10MB) |
target_language |
string | Po. | Target language code (e.g., "es", "fr", "de") |
source_language |
string | Jo. | Source language code. Default: "auto" (auto-detect) |
Llojet e suportuara të file
Dokumentet
.txt- File me tekst të thjeshtë.docx- Dokumente Word.pdf- Dokumente PDF (duke përfshirë ato të skanuara)
Të dhëna dhe lokalizim
.json- File JSON (përkthen vlerat e stringës).xml- File XML.srt- File të subtitrave.po/.pot- File të përkthimit Gettext
Figura (OCR)
.jpg/.jpeg- JPEG figura (OCR).png- Figurat PNG.tiff/.tif- Figurat TIFF (OCR).bmp- Figurat BMP (OCR).webp- Figurat WebP (OCR)
Shembull (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"
Përgjigje
{
"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}/
Kontrollo gjendjen e përkthimit të një dokumenti ose merr URL-në e shkarkimit.
Vlerat e gjendjes
pending |
File u ngarkua, në pritje të përpunimit |
processing |
Përkthimi në proces |
completed |
Përkthimi përfundoi, shkarkimi është në dispozicion |
failed |
Përkthimi dështoi (kontrollo error_message) |
Gjuhët e suportuara
Merr listën e të gjitha gjuhëve të suportuara.
GET https://api.translateapi.ai/api/v1/translate/languages/
Përgjigje
{
"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 përkthimi
Ne përdorim modele të përkthimit me burim të hapur që funksionojnë në infrastrukturën tonë GPU. Të gjithë modelet janë të licencuar komercialisht (Apache 2.0).
| Modeli | Gjuhë | Më e mira për |
|---|---|---|
| Helsinki-NLP/opus-mt | 50+ çifte gjuhësh | Gjuhët e zakonshme (EN, ES, FR, DE, IT, PT, RU, ZH, JA, etj.) |
| Google MADLAD-400 | 400+ gjuhë | Gjuhët e rralla, mbulim i plotë |
API zgjedh automatikisht modelin më të mirë për çiftin tuaj të gjuhës. Mund të specifikoni një engine Parametri:
| Motori | Përshkrimi |
|---|---|
"auto" |
E prezgjedhur. Përpiqet të përqafohet së pari, kthehet në MADLAD-400 |
"huggingface" |
Forco HuggingFace/MarianMT (më i shpejti, 50+ gjuhë) |
"madlad" |
Forca MADLAD-400 (400+ gjuhë) |
Manipulimi i gabimeve
API përdor kodet standarde të statusit HTTP për të treguar suksesin ose dështimin.
| Kodi | Përshkrimi |
|---|---|
| 200 | Suksesi |
| 202 | E pranuar — detyra e grupit u vendos me sukses në rradhë |
| 400 | Kërkesë e pavlefshme — Parametra të pavlefshëm (tekst që mungon, gjuhë e pasuportuar, etj.) |
| 401 | I paautorizuar - Kyç i pavlefshëm apo mungon kyçi API |
| 402 | Paga e nevojshme — Kreditët e karakterit janë harxhuar. Përmirëso planin tënd ose ble një rimbushje. |
| 403 | I ndaluar — kyçit të API i mungon ambijenti i kërkuar ose IP nuk është në listën e bardhë |
| 503 | Shërbimi nuk është në dispozicion - motori i përkthimit është përkohësisht jashtë funksionit |
Formati i përgjigjes së gabimit
{
"error": "insufficient_credits",
"credits_remaining": 0
}
Kufizime të përdorimit
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:
| Plani | Karakterë/Muaj | API e lotëve | Dokumentet | Çmimi | |
|---|---|---|---|---|---|
| I lirë | 250,000 | — | — | $0 | Regjistrohu pa pagesë |
| Fillues | 2,500,000 | $9/Mb | Regjistrohu | ||
| Pro | 10,000,000 | $29/Mb | Regjistrohu | ||
| Biznesi | 40,000,000 | $79/Mb | Regjistrohu | ||
| Shkalla | 125,000,000 | $199/Mb | Regjistrohu | ||
| Enterprise | Unlimited | $499/Mb | Contact Sales |
Kur të kalosh kufirin tënd, do të marrësh një 402 Payment Required përgjigje deri në muajin e ardhshëm ose ju përmirësoni.
Infrastruktura e Reve me Shkallëzim Automatik
TranslateAPI funksionon në instancat e dedikuara NVIDIA A100 GPU me shkallëzim automatik horizontal. Kur kërkesa rritet, instancat shtesë të GPU nisen brenda minutave për të mbajtur kohët e shpejta të përgjigjes. Të gjitha kërkesat vihen në radhë dhe përpunohen — dërgo qindra kërkesa në të njëjtën kohë dhe të gjitha do të trajtohen. Përkthimet në kohë reale marrin përparësi, proceset e grupeve në sfond.
Duhet më shumë kredi?
Të mungojnë karakterët në mes të muajit? Ble një kredit një herë pa ndryshuar planin. Shfaq paketat e rimbushjes