From a91303d27eb3169e0187935df100f4950739b2fd Mon Sep 17 00:00:00 2001 From: dingedi Date: Tue, 3 May 2022 16:30:20 +0200 Subject: [PATCH] improve translation formating --- app/app.py | 21 +++++++++++++++++++-- 1 file changed, 19 insertions(+), 2 deletions(-) diff --git a/app/app.py b/app/app.py index 8b14615..f3eccfc 100644 --- a/app/app.py +++ b/app/app.py @@ -474,6 +474,21 @@ def create_app(args): if text_format not in ["text", "html"]: abort(400, description="%s format is not supported" % text_format) + def improve_translation(source, translation): + if source.islower(): + return translation.lower() + + if source.isupper(): + return translation.upper() + + if source[0].islower(): + return translation[0].lower() + translation[1:] + + if source[0].isupper(): + return translation[0].upper() + translation[1:] + + return translation + try: if batch: results = [] @@ -483,7 +498,8 @@ def create_app(args): if text_format == "html": translated_text = str(translate_html(translator, text)) else: - translated_text = translator.translate(transliterate(text, target_lang=source_langs[idx]["language"])) + translated_text = improve_translation(text, translator.translate( + transliterate(text, target_lang=source_langs[idx]["language"]))) results.append(unescape(translated_text)) if source_lang == "auto": @@ -505,7 +521,8 @@ def create_app(args): if text_format == "html": translated_text = str(translate_html(translator, q)) else: - translated_text = translator.translate(transliterate(q, target_lang=source_langs[0]["language"])) + translated_text = improve_translation(q, translator.translate( + transliterate(q, target_lang=source_langs[0]["language"]))) if source_lang == "auto": return jsonify(