diff --git a/docutranslate/app.py b/docutranslate/app.py index f2ef543..946995e 100644 --- a/docutranslate/app.py +++ b/docutranslate/app.py @@ -376,6 +376,9 @@ class BaseWorkflowParams(BaseModel): None, description="用于术语表生成的Agent的配置。如果 `glossary_generate_enable` 为 `True`,此项必填。", ) + force_json: bool = Field( + default=False, description="应输出json格式时强制ai输出json" + ) @model_validator(mode="before") @classmethod @@ -907,6 +910,7 @@ async def _perform_translation( "timeout", "retry", "system_proxy_enable", + "force_json", }, exclude_none=True, ) @@ -969,6 +973,7 @@ async def _perform_translation( "timeout", "retry", "system_proxy_enable", + "force_json", }, exclude_none=True, ) @@ -1005,6 +1010,7 @@ async def _perform_translation( "timeout", "retry", "system_proxy_enable", + "force_json", }, exclude_none=True, ) @@ -1043,6 +1049,7 @@ async def _perform_translation( "timeout", "retry", "system_proxy_enable", + "force_json", }, exclude_none=True, ) @@ -1080,6 +1087,7 @@ async def _perform_translation( "timeout", "retry", "system_proxy_enable", + "force_json", }, exclude_none=True, ) @@ -1117,6 +1125,7 @@ async def _perform_translation( "timeout", "retry", "system_proxy_enable", + "force_json", }, exclude_none=True, ) @@ -1154,6 +1163,7 @@ async def _perform_translation( "timeout", "retry", "system_proxy_enable", + "force_json", }, exclude_none=True, ) @@ -1192,6 +1202,7 @@ async def _perform_translation( "timeout", "retry", "system_proxy_enable", + "force_json", }, exclude_none=True, ) @@ -1228,6 +1239,7 @@ async def _perform_translation( "timeout", "retry", "system_proxy_enable", + "force_json", }, exclude_none=True, ) diff --git a/docutranslate/static/i18nData.json b/docutranslate/static/i18nData.json index f9a2e65..c5c97ee 100644 --- a/docutranslate/static/i18nData.json +++ b/docutranslate/static/i18nData.json @@ -81,10 +81,13 @@ "baseUrlLabel": "API 地址 (Base URL)", "baseUrlPlaceholder": "OpenAi兼容地址", "getApiKeyTitle": "获取API Key", + "apiHrefInfo302ai": "👈 通过此链接注册可享1美元免费额度", "apiKeyPlaceholder": "请输入您的API Key", "modelIdLabel": "模型ID", "modelIdPlaceholder": "例如: gpt-4o, glm-4", "systemProxyLabel": "启用系统代理", + "forceJsonLabel": "强制json输出", + "forceJsonTooltip": "在需要json格式输出时强制模型输出json格式。可能会降低翻译质量,建议指令遵循强的模型关闭", "translationSettingsTitleText": "翻译配置", "targetLanguageLabel": "目标语言", "targetLanguageCustom": "其它 (自定义)", @@ -142,7 +145,7 @@ "closeBtn": "关闭", "downloadBtn": "下载", "tutorialModalTitle": "使用教程", - "tutorialModalBody": "

视频教程可以在B站搜索 docutranslate 获取。

\n

欢迎使用 DocuTranslate!请按照以下步骤完成文档翻译:

\n
    \n
  1. \n 第一步:选择工作流\n

    在左侧配置面板的顶部,首先选择最适合您文件类型的处理流程。\n

    \n 提示: 默认已开启“自动选择工作流”。您只需上传文件,系统会自动为您匹配合适的工作流,简化操作。\n
    \n

    \n \n
  2. \n
  3. \n 第二步:配置参数\n

    选择工作流后,下方会显示相关的配置选项。请依次完成设置(所有配置都会自动保存在您的浏览器中):

    \n

    A. 工作流特定选项 (根据您第一步的选择出现):

    \n \n

    B. 通用选项 (适用于所有工作流):

    \n \n
  4. \n
  5. \n 第三步:上传文件\n

    在右侧的任务列表中,点击或拖拽您的文档到文件上传区域。

    \n
  6. \n
  7. \n 第四步:开始翻译\n

    文件选择成功后,点击任务卡片右下角的 开始翻译 按钮。系统将开始处理任务,您可以在日志区域查看实时进度。

    \n
  8. \n
  9. \n 第五步:查看与下载\n

    翻译完成后,任务卡片下方会出现操作按钮:

    \n \n
  10. \n
\n
\n 重要提示: 所有配置都会自动保存在您的浏览器本地,方便下次使用。您也可以使用新增的“导出配置”和“导入配置”按钮来备份和恢复您的设置。\n
", + "tutorialModalBody": "

视频教程可以在B站搜索 docutranslate 获取。

欢迎使用 DocuTranslate!请按照以下步骤完成文档翻译:

  1. 第一步:选择工作流

    在左侧配置面板的顶部,首先选择最适合您文件类型的处理流程。

    提示: 默认已开启“自动选择工作流”。您只需上传文件,系统会自动为您匹配合适的工作流,简化操作。

  2. 第二步:配置参数

    选择工作流后,下方会显示相关的配置选项。请依次完成设置(所有配置都会自动保存在您的浏览器中):

    A. 工作流特定选项 (根据您第一步的选择出现):

    B. 通用选项 (适用于所有工作流):

  3. 第三步:上传文件

    在右侧的任务列表中,点击或拖拽您的文档到文件上传区域。

  4. 第四步:开始翻译

    文件选择成功后,点击任务卡片右下角的 开始翻译 按钮。系统将开始处理任务,您可以在日志区域查看实时进度。

  5. 第五步:查看与下载

    翻译完成后,任务卡片下方会出现操作按钮:

重要提示: 所有配置都会自动保存在您的浏览器本地,方便下次使用。您也可以使用新增的“导出配置”和“导入配置”按钮来备份和恢复您的设置。
", "tutorialUnderstandBtn": "我明白了", "contributorsModalTitle": "感谢贡献", "contributorsPara1": "DocuTranslate是一个开源项目!大家的需求与使用是项目进步的动力。", @@ -157,46 +160,45 @@ "glossaryTableDestination": "译文 (dst)", "init_i18n_failed_alert": "加载界面翻译资源失败,请检查网络连接或联系管理员。", "init_failed_alert": "初始化失败,无法连接到后端服务。请检查服务是否运行或刷新页面。", - "apiHrefInfo302ai": "👈 通过此链接注册可享1美元免费额度", - "engineOptionIdentity": "不做转换 (文件本身是.md格式)", + "engineOptionIdentity": "已经是Markdown格式", "engineOptionMineru": "Mineru (推荐)", "engineOptionDocling": "Docling", - "engineOptionMineruDeploy": "Mineru 部署服务", - "glossaryEmpty": "术语表为空或未加载。", - "status_selectFileFirst": "请先选择文件!", - "status_fillRequired": "请填写所有必填项!", + "engineOptionMineruDeploy": "Mineru部署服务", + "glossaryEmpty": "术语表为空", + "status_selectFileFirst": "请先选择文件", + "status_fillRequired": "请填写所有必填项", "btn_initializing": "初始化中...", - "status_encodingAndSubmitting": "文件编码并提交中...", + "status_encodingAndSubmitting": "文件编码和提交中...", "status_requestOk": "请求成功,任务已开始", "btn_cancelTranslation": "取消翻译", "status_requestFail": "请求失败", - "status_initFail": "初始化失败", + "status_initFail": "任务初始化失败", "status_cancelling": "取消中...", "status_cancelSent": "取消请求已发送", "status_cancelFail": "取消失败", "btn_reTranslate": "重新翻译", "status_gettingStatus": "获取状态中...", "status_updateError": "状态更新出错", - "pdf_preparing": "正在准备PDF,请稍候...", - "pdf_print_failed": "调用打印功能失败。请尝试手动保存为PDF。", - "pdf_fetch_failed": "获取HTML内容失败,无法生成PDF。", - "preview_loading": "加载预览中...", - "preview_cantReadOriginal": "无法读取原文文件内容进行预览。", + "preview_loading": "预览加载中...", + "preview_cantReadOriginal": "无法读取原始文件内容。", "preview_cantPreviewType": "无法预览此文件类型", - "preview_noOriginalCache": "无原文文件缓存,无法预览。", - "preview_loadFailed": "预览加载失败", + "preview_noOriginalCache": "没有缓存的原始文件可供预览。", + "preview_loadFailed": "预览加载失败。", + "pdf_preparing": "正在准备PDF以便打印...", + "pdf_print_failed": "调用打印功能失败。请尝试手动右键点击预览内容并选择打印。", + "pdf_fetch_failed": "获取预览内容失败,无法生成PDF。", "preview_bilingual": "双语预览", "preview_translatedOnly": "仅译文预览", - "admin_tasklist_failed": "管理员模式:加载任务列表失败。", + "admin_tasklist_failed": "管理员模式: 加载任务列表失败。", "configImportSuccess": "配置导入成功!界面已刷新。", - "configImportError": "配置导入失败,文件格式可能不正确。" + "configImportError": "配置导入失败,文件可能已损坏或格式不正确。" }, "en": { "pageTitle": "DocuTranslate - Interactive Document Translation", "tutorialBtn": "Tutorial", "projectContributeBtn": "Contribute", "workflowTitle": "Select Workflow", - "workflowOptionMarkdown": "To Markdown then Translate (.pdf/.md/.png, etc.)", + "workflowOptionMarkdown": "To Markdown & Translate (.pdf/.md/.png, etc.)", "workflowOptionTxt": "Plain Text Translation (.txt)", "workflowOptionEpub": "EPUB Translation (.epub)", "workflowOptionDocx": "DOCX Translation (.docx)", @@ -208,45 +210,45 @@ "autoWorkflowLabel": "Auto-select workflow", "txtSettingsTitleText": "TXT Translation Options", "insertModeLabel": "Insert Mode", - "insertModeReplace": "Replace original text", - "insertModeAppend": "Append to original text", - "insertModePrepend": "Prepend to original text", - "insertModeHelpTxt": "Choose how the translated text is inserted.", + "insertModeReplace": "Replace Original", + "insertModeAppend": "Append to Original", + "insertModePrepend": "Prepend to Original", + "insertModeHelpTxt": "Choose how to insert the translated text.", "separatorLabel": "Separator", "separatorPlaceholderSimple": "e.g., \\n---\\n", - "separatorHelp": "Characters used to separate original and translated text in append/prepend modes. \\n represents a new line.", + "separatorHelp": "Characters to separate original and translated text in append/prepend mode. \\n for newline.", "segmentModeLabel": "Segment Mode", "segmentModeLine": "By Line (Each line is a segment)", "segmentModeParagraph": "By Paragraph (Merge consecutive non-empty lines)", "segmentModeNone": "No Segmentation (Entire text is one segment)", "segmentModeHelp": "Choose how to split the text into chunks for translation.", "docxSettingsTitleText": "DOCX Translation Options", - "insertModeHelpDocx": "Choose how the translated text is inserted.", + "insertModeHelpDocx": "Choose how to insert the translated text.", "separatorPlaceholderStructured": "e.g., ---", - "separatorHelpDocx": "In append mode, the translation will be in a new paragraph. This adds extra content between them. \\n can be used for new lines within the separator.", + "separatorHelpDocx": "In append mode, translation starts in a new paragraph. This adds content between original and translated paragraphs. \\n for internal newlines.", "xlsxSettingsTitleText": "XLSX Translation Options", - "insertModeHelpXlsx": "Choose how the translated text is inserted into cells.", + "insertModeHelpXlsx": "Choose how to insert translated text into cells.", "xlsxTranslateRegionsLabel": "Translate Regions (Optional)", "xlsxTranslateRegionsPlaceholder": "One region per line, e.g., Sheet1!A1:B10 (applies to all sheets if sheet name is omitted)", "srtSettingsTitleText": "SRT Translation Options", - "insertModeHelpSrt": "Choose how the translated text is inserted.", + "insertModeHelpSrt": "Choose how to insert the translated text.", "epubSettingsTitleText": "EPUB Translation Options", - "insertModeHelpEpub": "Choose how the translated text is inserted.", - "separatorHelpEpub": "In append mode, the translation will be a new block. This adds extra content between them. \\n can be used for new lines within the separator.", + "insertModeHelpEpub": "Choose how to insert the translated text.", + "separatorHelpEpub": "In append mode, translation starts in a new block. This adds content between original and translated blocks. \\n for internal newlines.", "htmlSettingsTitleText": "HTML Translation Options", - "insertModeHelpHtml": "Choose how the translated text is inserted.", - "separatorHelpHtml": "In append mode, the translation will be a new block. This adds extra content between them. \\n can be used for new lines within the separator.", + "insertModeHelpHtml": "Choose how to insert the translated text.", + "separatorHelpHtml": "In append mode, translation starts in a new block. This adds content between original and translated blocks. \\n for internal newlines.", "assSettingsTitleText": "ASS Translation Options", - "insertModeHelpAss": "Choose how the translated text is inserted.", - "separatorPlaceholderAss": "e.g., \\N (newline character)", - "separatorHelpAss": "Characters used to separate original and translated text in append/prepend modes. \\N is the newline character for ASS format.", + "insertModeHelpAss": "Choose how to insert the translated text.", + "separatorPlaceholderAss": "e.g., \\N (newline)", + "separatorHelpAss": "Characters to separate original and translated text in append/prepend mode. \\N is the newline for ASS format.", "jsonSettingsTitleText": "JSON Path Configuration", "jsonPathLabel": "JSON Paths to Translate", - "jsonPathPlaceholder": "One path per line, e.g.:\n$.name\n$.*", - "jsonPathHelp": "Uses jsonpath-ng syntax. Each line represents a JSON path. All strings within matching objects will be translated.", + "jsonPathPlaceholder": "One path per line, e.g.,\n$.name\n$.*", + "jsonPathHelp": "Uses jsonpath-ng syntax. One JSON path per line. All strings within matching objects will be translated.", "parsingSettingsTitleText": "Parsing Configuration", "parsingEngineLabel": "Parsing Engine", - "parsingEngineHelp": "This can be skipped if the uploaded file is already in .md format.", + "parsingEngineHelp": "Not required if the uploaded file is already in .md format.", "getMineruTokenTitle": "Get Mineru Token", "mineruTokenPlaceholder": "Required when using Mineru engine", "modelVersionLabel": "Mineru Model Version", @@ -273,39 +275,42 @@ "baseUrlLabel": "API Address (Base URL)", "baseUrlPlaceholder": "OpenAI-compatible address", "getApiKeyTitle": "Get API Key", + "apiHrefInfo302ai": "👈 Register via this link for a $1 free credit", "apiKeyPlaceholder": "Please enter your API Key", "modelIdLabel": "Model ID", "modelIdPlaceholder": "e.g., gpt-4o, glm-4", "systemProxyLabel": "Enable System Proxy", + "forceJsonLabel": "Force JSON Output", + "forceJsonTooltip": "Force the model to output in JSON format. May reduce translation quality. Recommended to disable for models with strong instruction following.", "translationSettingsTitleText": "Translation Configuration", "targetLanguageLabel": "Target Language", "targetLanguageCustom": "Other (Custom)", "customLangPlaceholder": "Enter target language, e.g., Italian", "thinkingModeLabel": "Thinking Mode", - "thinkingModeTooltip": "Sets whether the hybrid inference model should 'think'. Currently supported by Zhipu glm4.5 series, Volcengine seed1.6 series, SiliconFlow, Google Gemini series, 302AI (partial). Disabling is recommended.", + "thinkingModeTooltip": "Sets whether mixed-reasoning models should 'think'. Supported by Zhipu glm4.5 series, Volcengine seed1.6 series, SiliconFlow, Google Gemini series, 302AI (partial). Disabling is recommended.", "thinkingModeEnable": "Enable", "thinkingModeDisable": "Disable (Recommended)", "thinkingModeDefault": "Default", "customPromptLabel": "Custom Prompt", - "customPromptPlaceholder": "Optional, e.g., 'Keep personal names in their original language'", + "customPromptPlaceholder": "Optional, e.g., \"Do not translate proper names.\"", "chunkSizeLabel": "Chunk Size", "resetBtn": "Reset", "concurrentLabel": "Concurrency", "retryLabel": "Retries", "glossaryGenTitle": "Glossary", "glossaryLabel": "Glossary (Optional)", - "glossaryHelp": "Select one or more CSV files. Files must have 'src' and 'dst' columns for source and destination terms.", + "glossaryHelp": "Select one or more CSV files. Files must contain 'src' and 'dst' headers for source and destination terms.", "viewGlossaryBtn": "View Glossary", "clearGlossaryBtn": "Clear", "glossaryGenEnableLabel": "Auto-generate Glossary", "glossaryCustomPromptLabel": "Custom Prompt", "glossaryCustomPromptPlaceholder": "Prompt for glossary generation", "glossaryGenConfigLabel": "Glossary Generation Config", - "glossaryGenConfigSame": "Same as Translation Config", + "glossaryGenConfigSame": "Same as Translation", "glossaryGenConfigCustom": "Custom", "importConfigBtn": "Import Config", "exportConfigBtn": "Export Config", - "githubInfo": "GitHub Page (Star us❤):
\n https://github.com/xunbu/docutranslate", + "githubInfo": "GitHub Home (stars❤ welcome):
\n https://github.com/xunbu/docutranslate", "qqGroupInfo": "QQ Group: 1047781902", "taskListTitle": "Task List", "newTaskBtn": "New Task", @@ -322,65 +327,64 @@ "taskCardDownloadBtn": "Download", "taskCardAttachmentBtn": "Attachments", "taskCardStartBtn": "Start Translation", - "downloadMdEmbedded": "Markdown (Embedded Imgs)", + "downloadMdEmbedded": "Markdown (Embedded Img)", "downloadMdZip": "Markdown Zip", "downloadAss": "ASS", "previewTitle": "Preview", "previewBilingualBtn": "Bilingual", - "previewTranslatedOnlyBtn": "Translation Only", + "previewTranslatedOnlyBtn": "Translated Only", "syncScrollTooltip": "Sync Scrolling", "previewOriginal": "Original", "previewTranslated": "Translation", "closeBtn": "Close", "downloadBtn": "Download", - "tutorialModalTitle": "User Guide", - "tutorialModalBody": "

Video tutorials are available on Bilibili by searching for docutranslate.

\n

Welcome to DocuTranslate! Follow these steps to translate your documents:

\n
    \n
  1. \n Step 1: Select Workflow\n

    At the top of the left settings panel, first choose the process that best suits your file type.\n

    \n Tip: \"Auto-select workflow\" is enabled by default. Just upload your file, and the system will automatically match the appropriate workflow for you.\n
    \n

    \n \n
  2. \n
  3. \n Step 2: Configure Parameters\n

    After selecting a workflow, related options will appear below. Please configure them sequentially (all settings are saved automatically in your browser):

    \n

    A. Workflow-Specific Options (Appear based on your choice in Step 1):

    \n \n

    B. General Options (Apply to all workflows):

    \n \n
  4. \n
  5. \n Step 3: Upload File\n

    In the task list on the right, click or drag your document into the file upload area.

    \n
  6. \n
  7. \n Step 4: Start Translation\n

    Once the file is selected, click the Start Translation button on the task card. The system will begin processing, and you can monitor the progress in the log area.

    \n
  8. \n
  9. \n Step 5: View and Download\n

    When translation is complete, action buttons will appear on the task card:

    \n \n
  10. \n
\n
\n Important: All your settings are saved locally in your browser for convenience. You can also use the new \"Export Config\" and \"Import Config\" buttons to back up and restore your settings.\n
", - "tutorialUnderstandBtn": "I Understand", + "tutorialModalTitle": "Tutorial", + "tutorialModalBody": "

Video tutorials are available on Bilibili by searching for docutranslate.

Welcome to DocuTranslate! Follow these steps to translate your documents:

  1. Step 1: Select Workflow

    At the top of the left settings panel, first choose the processing flow that best suits your file type.

    Tip: 'Auto-select workflow' is enabled by default. Just upload your file, and the system will automatically match the appropriate workflow for you.

  2. Step 2: Configure Parameters

    After selecting a workflow, relevant configuration options will appear below. Please complete the settings in order (all configurations are automatically saved in your browser):

    A. Workflow-Specific Options (Appear based on your Step 1 choice):

    B. General Options (Applicable to all workflows):

  3. Step 3: Upload File

    In the task list on the right, click or drag your document into the file upload area.

  4. Step 4: Start Translation

    After the file is selected, click the Start Translation button on the task card. The system will begin processing, and you can watch the real-time progress in the log area.

  5. Step 5: View & Download

    Once translation is complete, action buttons will appear on the task card:

Important Note: All settings are automatically saved locally in your browser for future use. You can also use the new 'Export Config' and 'Import Config' buttons to back up and restore your settings.
", + "tutorialUnderstandBtn": "I understand", "contributorsModalTitle": "Thanks for Contributing", - "contributorsPara1": "DocuTranslate is an open-source project! The needs and usage of the community are the driving force behind its progress.", + "contributorsPara1": "DocuTranslate is an open-source project! The community's needs and usage are the driving force behind its progress.", "contributorsPara2": "A heartfelt thank you to everyone who has funded the project, submitted code, provided valuable suggestions, and starred the project!", - "contributorsWelcome": "You are welcome to contribute in the following ways:", - "contributorsGithub": "GitHub Page", + "contributorsWelcome": "You're welcome to contribute in the following ways:", + "contributorsGithub": "GitHub Home", "contributorsPR": "Submit a Pull Request", "contributorsIssue": "Report an Issue", - "contributorsQQ": "Or contact the author via QQ group: 1047781902", + "contributorsQQ": "Or contact the author via QQ Group: 1047781902", "glossaryModalTitle": "Current Glossary", "glossaryTableSource": "Source (src)", "glossaryTableDestination": "Destination (dst)", "init_i18n_failed_alert": "Failed to load interface translations. Please check your network connection or contact an administrator.", "init_failed_alert": "Initialization failed, could not connect to the backend service. Please ensure the service is running and refresh the page.", - "apiHrefInfo302ai": "👈 Register through this link to enjoy a $1 free credit", - "engineOptionIdentity": "No conversion (file is already .md)", + "engineOptionIdentity": "Already in Markdown format", "engineOptionMineru": "Mineru (Recommended)", "engineOptionDocling": "Docling", "engineOptionMineruDeploy": "Mineru Deploy Service", - "glossaryEmpty": "Glossary is empty or not loaded.", - "status_selectFileFirst": "Please select a file first!", - "status_fillRequired": "Please fill in all required fields!", + "glossaryEmpty": "Glossary is empty", + "status_selectFileFirst": "Please select a file first", + "status_fillRequired": "Please fill in all required fields", "btn_initializing": "Initializing...", "status_encodingAndSubmitting": "Encoding and submitting file...", "status_requestOk": "Request successful, task started", "btn_cancelTranslation": "Cancel Translation", "status_requestFail": "Request failed", - "status_initFail": "Initialization failed", + "status_initFail": "Task initialization failed", "status_cancelling": "Cancelling...", - "status_cancelSent": "Cancel request sent", + "status_cancelSent": "Cancellation request sent", "status_cancelFail": "Cancellation failed", "btn_reTranslate": "Re-translate", "status_gettingStatus": "Getting status...", "status_updateError": "Error updating status", - "pdf_preparing": "Preparing PDF, please wait...", - "pdf_print_failed": "Failed to invoke print function. Please try saving as PDF manually.", - "pdf_fetch_failed": "Failed to fetch HTML content, cannot generate PDF.", "preview_loading": "Loading preview...", - "preview_cantReadOriginal": "Could not read original file for preview.", + "preview_cantReadOriginal": "Could not read original file content.", "preview_cantPreviewType": "Cannot preview this file type", - "preview_noOriginalCache": "No original file cached, cannot preview.", - "preview_loadFailed": "Failed to load preview", + "preview_noOriginalCache": "No cached original file to preview.", + "preview_loadFailed": "Failed to load preview.", + "pdf_preparing": "Preparing PDF for printing...", + "pdf_print_failed": "Failed to invoke print function. Please try right-clicking the preview content and selecting Print manually.", + "pdf_fetch_failed": "Failed to fetch preview content, cannot generate PDF.", "preview_bilingual": "Bilingual Preview", - "preview_translatedOnly": "Translation-Only Preview", + "preview_translatedOnly": "Translated Only Preview", "admin_tasklist_failed": "Admin mode: Failed to load task list.", - "configImportSuccess": "Configuration imported successfully! The UI has been updated.", - "configImportError": "Failed to import configuration, the file format may be incorrect." + "configImportSuccess": "Configuration imported successfully! The interface has been updated.", + "configImportError": "Failed to import configuration. The file may be corrupt or incorrectly formatted." } } \ No newline at end of file diff --git a/docutranslate/static/index.html b/docutranslate/static/index.html index 076ee44..cd4e8c2 100644 --- a/docutranslate/static/index.html +++ b/docutranslate/static/index.html @@ -1 +1 @@ - DocuTranslate - 交互式文档翻译

DocuTranslate

如果上传的文件本身是.md格式,此项可不选。

Base URL:

选择一个或多个CSV文件。文件需包含'src'和'dst'两列标题,分别代表原文和译文。

GitHub主页(欢迎star❤):
https://github.com/xunbu/docutranslate

交流QQ群: 1047781902

version:

任务列表

LOGO

当前没有任务,点击“新建任务”开始吧!

预览
原文
译文
\ No newline at end of file + DocuTranslate - 交互式文档翻译

DocuTranslate

如果上传的文件本身是.md格式,此项可不选。

Base URL:

选择一个或多个CSV文件。文件需包含'src'和'dst'两列标题,分别代表原文和译文。

GitHub主页(欢迎star❤):
https://github.com/xunbu/docutranslate

交流QQ群: 1047781902

version:

任务列表

LOGO

当前没有任务,点击“新建任务”开始吧!

预览
原文
译文
\ No newline at end of file diff --git a/docutranslate/translator/ai_translator/ass_translator.py b/docutranslate/translator/ai_translator/ass_translator.py index 6173a6d..5550183 100644 --- a/docutranslate/translator/ai_translator/ass_translator.py +++ b/docutranslate/translator/ai_translator/ass_translator.py @@ -39,7 +39,8 @@ class AssTranslator(AiTranslator): logger=self.logger, glossary_dict=config.glossary_dict, retry=config.retry, - system_proxy_enable=config.system_proxy_enable + system_proxy_enable=config.system_proxy_enable, + json_format=config.force_json ) self.translate_agent = SegmentsTranslateAgent(agent_config) self.insert_mode = config.insert_mode diff --git a/docutranslate/translator/ai_translator/base.py b/docutranslate/translator/ai_translator/base.py index 978c575..2c19f19 100644 --- a/docutranslate/translator/ai_translator/base.py +++ b/docutranslate/translator/ai_translator/base.py @@ -26,7 +26,7 @@ class AiTranslatorConfig(TranslatorConfig, AgentConfig): glossary_generate_enable: bool = False glossary_agent_config: GlossaryAgentConfig | None = None skip_translate: bool = False # 当skip_translate为False时base_url、model_id为必填项 - + force_json:bool=False # 应输出json格式时强制ai输出json T = TypeVar("T", bound=Document) diff --git a/docutranslate/translator/ai_translator/docx_translator.py b/docutranslate/translator/ai_translator/docx_translator.py index 60673e1..4695af3 100644 --- a/docutranslate/translator/ai_translator/docx_translator.py +++ b/docutranslate/translator/ai_translator/docx_translator.py @@ -129,7 +129,7 @@ class DocxTranslator(AiTranslator): api_key=config.api_key, model_id=config.model_id, temperature=config.temperature, thinking=config.thinking, concurrent=config.concurrent, timeout=config.timeout, logger=self.logger, glossary_dict=config.glossary_dict, retry=config.retry, - system_proxy_enable=config.system_proxy_enable + system_proxy_enable=config.system_proxy_enable,json_format=config.force_json ) self.translate_agent = SegmentsTranslateAgent(agent_config) self.insert_mode = config.insert_mode diff --git a/docutranslate/translator/ai_translator/epub_translator.py b/docutranslate/translator/ai_translator/epub_translator.py index 7fa43b1..336617c 100644 --- a/docutranslate/translator/ai_translator/epub_translator.py +++ b/docutranslate/translator/ai_translator/epub_translator.py @@ -50,7 +50,8 @@ class EpubTranslator(AiTranslator): logger=self.logger, glossary_dict=config.glossary_dict, retry=config.retry, - system_proxy_enable=config.system_proxy_enable + system_proxy_enable=config.system_proxy_enable, + json_format=config.force_json ) self.translate_agent = SegmentsTranslateAgent(agent_config) self.insert_mode = config.insert_mode diff --git a/docutranslate/translator/ai_translator/html_translator.py b/docutranslate/translator/ai_translator/html_translator.py index 2902dd9..651bfb6 100644 --- a/docutranslate/translator/ai_translator/html_translator.py +++ b/docutranslate/translator/ai_translator/html_translator.py @@ -68,7 +68,8 @@ class HtmlTranslator(AiTranslator): logger=self.logger, glossary_dict=config.glossary_dict, retry=config.retry, - system_proxy_enable=config.system_proxy_enable + system_proxy_enable=config.system_proxy_enable, + json_format=config.force_json ) self.translate_agent = SegmentsTranslateAgent(agent_config) self.insert_mode = config.insert_mode diff --git a/docutranslate/translator/ai_translator/json_translator.py b/docutranslate/translator/ai_translator/json_translator.py index 72beb01..ca3ba9d 100644 --- a/docutranslate/translator/ai_translator/json_translator.py +++ b/docutranslate/translator/ai_translator/json_translator.py @@ -36,7 +36,8 @@ class JsonTranslator(AiTranslator): logger=self.logger, glossary_dict=config.glossary_dict, retry=config.retry, - system_proxy_enable=config.system_proxy_enable + system_proxy_enable=config.system_proxy_enable, + json_format=config.force_json ) self.translate_agent = SegmentsTranslateAgent(agent_config) self.json_paths = config.json_paths diff --git a/docutranslate/translator/ai_translator/srt_translator.py b/docutranslate/translator/ai_translator/srt_translator.py index fc69d3a..0434ae2 100644 --- a/docutranslate/translator/ai_translator/srt_translator.py +++ b/docutranslate/translator/ai_translator/srt_translator.py @@ -41,7 +41,8 @@ class SrtTranslator(AiTranslator): logger=self.logger, glossary_dict=config.glossary_dict, retry=config.retry, - system_proxy_enable=config.system_proxy_enable + system_proxy_enable=config.system_proxy_enable, + json_format=config.force_json ) self.translate_agent = SegmentsTranslateAgent(agent_config) self.insert_mode = config.insert_mode diff --git a/docutranslate/translator/ai_translator/txt_translator.py b/docutranslate/translator/ai_translator/txt_translator.py index e214243..880d07b 100644 --- a/docutranslate/translator/ai_translator/txt_translator.py +++ b/docutranslate/translator/ai_translator/txt_translator.py @@ -66,7 +66,8 @@ class TXTTranslator(AiTranslator): logger=self.logger, glossary_dict=config.glossary_dict, retry=config.retry, - system_proxy_enable=config.system_proxy_enable + system_proxy_enable=config.system_proxy_enable, + json_format=config.force_json ) self.translate_agent = SegmentsTranslateAgent(agent_config) self.insert_mode = config.insert_mode diff --git a/docutranslate/translator/ai_translator/xlsx_translator.py b/docutranslate/translator/ai_translator/xlsx_translator.py index c5916e8..ebfef78 100644 --- a/docutranslate/translator/ai_translator/xlsx_translator.py +++ b/docutranslate/translator/ai_translator/xlsx_translator.py @@ -45,7 +45,8 @@ class XlsxTranslator(AiTranslator): logger=self.logger, glossary_dict=config.glossary_dict, retry=config.retry, - system_proxy_enable=config.system_proxy_enable + system_proxy_enable=config.system_proxy_enable, + json_format=config.force_json ) self.translate_agent = SegmentsTranslateAgent(agent_config) self.insert_mode = config.insert_mode