Pdfmathtranslate
    Pdfmathtranslate

    Pdfmathtranslate

    PDF scientific paper translation with preserved formats - 基于 AI 完整保留排版的 PDF 文档全文双语翻译,支持 Google/DeepL/Ollama/OpenAI 等服务,提供 CLI/GUI/MCP/Docker/Zotero

    4.3

    GitHub Stats

    Stars

    25529

    Forks

    2165

    Release Date

    6/19/2025

    about two weeks ago

    Detailed Description

    English | 简体中文 | 繁體中文 | 日本語 | 한국어

    PDF scientific paper translation and bilingual comparison.

    • 📊 Preserve formulas, charts, table of contents, and annotations (preview).
    • 🌐 Support multiple languages, and diverse translation services.
    • 🤖 Provides commandline tool, interactive user interface, and Docker

    Feel free to provide feedback in GitHub Issues or Telegram Group.

    For details on how to contribute, please consult the Contribution Guide.

    • [May 9, 2025] pdf2zh 2.0 Preview Version #586: The Windows ZIP file and Docker image are now available.

    [!NOTE]

    2.0 Moved to a new repository under the organization: PDFMathTranslate/PDFMathTranslate-next

    Version 2.0 official release has been published.

    • [Mar. 3, 2025] Experimental support for the new backend BabelDOC WebUI added as an experimental option (by @awwaawwa)
    • [Feb. 22 2025] Better release CI and well-packaged windows-amd64 exe (by @awwaawwa)
    • [Dec. 24 2024] The translator now supports local models on Xinference (by @imClumsyPanda)
    • [Dec. 19 2024] Non-PDF/A documents are now supported using -cp (by @reycn)
    • [Dec. 13 2024] Additional support for backend by (by @YadominJinta)
    • [Dec. 10 2024] The translator now supports OpenAI models on Azure (by @yidasanqian)

    You can try our application out using either of the following demos:

    Note that the computing resources of the demo are limited, so please avoid abusing them.

    Methods

    For different use cases, we provide distinct methods to use our program:

    1. Python installed (3.10 <= version <= 3.12)

    2. Install our package:

      pip install uv
      uv tool install --python 3.12 pdf2zh
      
    3. Execute translation, files generated in current working directory:

      pdf2zh document.pdf
      
    1. Download pdf2zh-version-win64.zip from release page

    2. Unzip and double-click pdf2zh.exe to run.

    1. Python installed (3.10 <= version <= 3.12)

    2. Install our package:

    pip install pdf2zh
    
    1. Start using in browser:

      pdf2zh -i
      
    2. If your browser has not been started automatically, goto

      http://localhost:7860/
      

      See documentation for GUI for more details.

    1. Pull and run:

      docker pull byaidu/pdf2zh
      docker run -d -p 7860:7860 byaidu/pdf2zh
      
    2. Open in browser:

      http://localhost:7860/
      

    For docker deployment on cloud service:

    See Zotero PDF2zh for more details.

    1. Python installed (3.10 <= version <= 3.12)

    2. Install our package:

      pip install pdf2zh
      
    3. Execute translation, files generated in current working directory:

      pdf2zh document.pdf
      

    [!TIP]

    docker pull ghcr.io/byaidu/pdfmathtranslate
    docker run -d -p 7860:7860 ghcr.io/byaidu/pdfmathtranslate
    

    Unable to install?

    The present program needs an AI model(wybxc/DocLayout-YOLO-DocStructBench-onnx) before working and some users are not able to download due to network issues. If you have a problem with downloading this model, we provide a workaround using the following environment variable:

    set HF_ENDPOINT=https://hf-mirror.com
    

    For PowerShell user:

    $env:HF_ENDPOINT = https://hf-mirror.com
    

    If the solution does not work to you / you encountered other issues, please refer to frequently asked questions.

    Execute the translation command in the command line to generate the translated document example-mono.pdf and the bilingual document example-dual.pdf in the current working directory. Use Google as the default translation service. More support translation services can find HERE.

    In the following table, we list all advanced options for reference:

    | Option | Function | Example | | --------------------- | ------------------------------------------------------------------------------------------------------------- | ---------------------------------------------- | | files | Local files | pdf2zh ~/local.pdf | | links | Online files | pdf2zh http://arxiv.org/paper.pdf | | -i | Enter GUI | pdf2zh -i | | -p | Partial document translation | pdf2zh example.pdf -p 1 | | -li | Source language | pdf2zh example.pdf -li en | | -lo | Target language | pdf2zh example.pdf -lo zh | | -s | Translation service | pdf2zh example.pdf -s deepl | | -t | Multi-threads | pdf2zh example.pdf -t 1 | | -o | Output dir | pdf2zh example.pdf -o output | | -f, -c | Exceptions | pdf2zh example.pdf -f "(MS.*)" | | -cp | Compatibility Mode | pdf2zh example.pdf --compatible | | --skip-subset-fonts | Skip font subset | pdf2zh example.pdf --skip-subset-fonts | | --ignore-cache | Ignore translate cache | pdf2zh example.pdf --ignore-cache | | --share | Public link | pdf2zh -i --share | | --authorized | Authorization | pdf2zh -i --authorized users.txt [auth.html] | | --prompt | Custom Prompt | pdf2zh --prompt [prompt.txt] | | --onnx | [Use Custom DocLayout-YOLO ONNX model] | pdf2zh --onnx [onnx/model/path] | | --serverport | [Use Custom WebUI port] | pdf2zh --serverport 7860 | | --dir | [batch translate] | pdf2zh --dir /path/to/translate/ | | --config | configuration file | pdf2zh --config /path/to/config/config.json | | --serverport | [custom gradio server port] | pdf2zh --serverport 7860 | | --babeldoc | Use Experimental backend BabelDOC to translate | pdf2zh --babeldoc -s openai example.pdf | | --mcp | Enable MCP STDIO mode | pdf2zh --mcp | | --sse | Enable MCP SSE mode | pdf2zh --mcp --sse |

    For detailed explanations, please refer to our document about Advanced Usage for a full list of each option.

    For downstream applications, please refer to our document about API Details for further information about:

    • Python API, how to use the program in other Python programs
    • HTTP API, how to communicate with a server with the program installed
    • [ ] Parse layout with DocLayNet based models, PaddleX, PaperMage, SAM2

    • [ ] Fix page rotation, table of contents, format of lists

    • [ ] Fix pixel formula in old papers

    • [ ] Async retry except KeyboardInterrupt

    • [ ] Knuth–Plass algorithm for western languages

    • [ ] Support non-PDF/A files

    • [ ] Plugins of Zotero and Obsidian

    Alt

    Star History

    Star History

    Sep 15Oct 12Oct 16Oct 20Oct 28Nov 1Nov 5Nov 9Nov 13Nov 2005501,1001,6502,200
    Powered by MSeeP Analytics

    About the Project

    This app has not been claimed by its owner yet.

    Claim Ownership

    Receive Updates

    Security Updates

    Get notified about trust rating changes

    to receive email notifications.