This is an unofficial, DeepL API wrapper for Nodejs written in Typescript.
Official documentation: https://www.deepl.com/api.html
$ npm install trkbt10/unofficial-deepl-client
import * as DeepL from "unofficial-deepl-client";
const token = process.env.DEEPL_AUTH_KEY ?? "";
const deepL = new DeepL.WebClient(token);
deepL.translate({
text: "山路を登りながら、こう考えた。",
sourceLang: "JA",
targetLang: "EN",
splitSentences: false,
preserveFormatting: false,
formality: "default",
}).then((data) => {
/*
{
translations: [
{
detectedSourceLanguage: "JA",
text: "As I climbed the mountain road, I thought about this.",
},
],
}
*/
console.log(data);
})
https://www.deepl.com/docs-api/translating-documents/#translating-text
type TranslatingTextRequestParameters = {
text: string | string[];
sourceLang?: DeepL.SourceLanguage;
targetLang: DeepL.TargetLanguage;
splitSentences?: boolean | "nonewlines";
preserveFormatting: boolean;
formality: "default" | "more" | "less" | string;
};
const params:TranslatingTextRequestParameters = {
text: "山路を登りながら、こう考えた。",
sourceLang: "JA",
targetLang: "EN",
splitSentences: false,
preserveFormatting: false,
formality: "default",
};
const response = await deepL.translate(params);
/*
{
translations: [
{
detectedSourceLanguage: "JA",
text: "As I climbed the mountain road, I thought about this.",
},
],
}
*/
console.log(response);
https://www.deepl.com/docs-api/translating-documents/#multiple-sentences
const response = await deepL.translate({
text: ["This is the first sentence.", "This is the second sentence.", "This is the third sentence."],
sourceLang: "EN",
targetLang: "DE",
splitSentences: true,
preserveFormatting: false,
formality: "default",
});
/*
{
translations: [
{ detectedSourceLanguage: "EN", text: "Dies ist der erste Satz." },
{ detectedSourceLanguage: "EN", text: "Dies ist der zweite Satz." },
{ detectedSourceLanguage: "EN", text: "Dies ist der dritte Satz." },
],
}
*/
console.log(response)
https://www.deepl.com/docs-api/translating-documents/#uploading
const sourceDocFile = fs.readFileSync("/document/path/doc.docx");
type UploadDocumentParameters = {
sourceLang?: DeepL.SourceLanguage;
targetLang: DeepL.TargetLanguage;
file: Buffer;
filename?: string;
};
const params:UploadDocumentParameters = {
targetLang: "JA",
file: sourceDocFile,
filename: "mydoc.docx",
};
const response = await deepL.uploadDocument(params);
/*
{
documentId: "DOCUMENT_ID",
documentKey: "DOCUMENT_KEY"
}
*/
console.log(response);
https://www.deepl.com/docs-api/translating-documents/#checking-status
const documentInfo = {
documentId: "DOCUMENT_ID",
documentKey: "DOCUMENT_KEY"
}
const response = await deepL.checkDocumentsTranslationStatus(documentInfo);
/*
{
documentId: "DOCUMENT_ID",
status: "done";
billedCharacters: 10000;
}
*/
console.log(response);
https://www.deepl.com/docs-api/translating-documents/#downloading
const documentInfo = {
documentId: "DOCUMENT_ID",
documentKey: "DOCUMENT_KEY"
}
const buffer = await deepL.downloadTranslatedDocument(documentInfo);
fs.writeFileSync('translatedDocument.docx', buffer);
https://www.deepl.com/docs-api/other-functions/monitoring-usage/#monitoring-usage
const response = await deepL.monitoringUsage();
/*
{
"characterCount": 180118,
"characterLimit": 1250000
}
*/
console.log(response);
https://www.deepl.com/docs-api/other-functions/monitoring-usage/#listing-supported-languages
const response = await deepL.getSupportedLanguages();
/*
[
{
"language": "DE",
"name": "Deutsch"
},
{
"language": "EN",
"name": "English"
},
...
]
*/
console.log(response);