From 76924345955c87ac6ed0e0912efba4c8ba99b37e Mon Sep 17 00:00:00 2001 From: Byaidu <909756245@qq.com> Date: Fri, 20 Dec 2024 23:05:43 +0800 Subject: [PATCH] fix: ollama reraise --- pdf2zh/translator.py | 46 ++++++++++++++++---------------------------- 1 file changed, 17 insertions(+), 29 deletions(-) diff --git a/pdf2zh/translator.py b/pdf2zh/translator.py index c514bec6..d816c165 100644 --- a/pdf2zh/translator.py +++ b/pdf2zh/translator.py @@ -213,37 +213,25 @@ def __init__(self, lang_in, lang_out, model, envs=None, prompt=None): self.prompttext = prompt def translate(self, text): - print(len(self.prompt(text, self.prompttext))) - print(self.prompt(text, self.prompttext)[0]) - print(self.prompt(text, self.prompttext)[1]) - maxlen = max(2000, len(text) * 3) + maxlen = max(2000, len(text) * 5) for model in self.model.split(";"): - for i in range(2): - if i: - print("[Retry]") + try: response = "" - try: - stream = self.client.chat( - model=model, - options=self.options, - messages=self.prompt(text, self.prompttext), - stream=True, - ) - for chunk in stream: - chunk = chunk["message"]["content"] - print(chunk, end="", flush=True) - response += chunk - if len(response) > maxlen: - raise Exception("Response too long") - if not response.endswith("\n"): - print() - return response.strip() - except Exception as e: - print() - print(e) - print("[Aborted.]") - # if translation fails after multiple retries, return the original text to prevent hang-up - return text + stream = self.client.chat( + model=model, + options=self.options, + messages=self.prompt(text, self.prompttext), + stream=True, + ) + for chunk in stream: + chunk = chunk["message"]["content"] + response += chunk + if len(response) > maxlen: + raise Exception("Response too long") + return response.strip() + except Exception as e: + print(e) + raise Exception("All models failed") class OpenAITranslator(BaseTranslator):