Нет описания

Byaidu f30133e040 Merge pull request #431 from timelic/dev/dynamic-line-space 1 год назад
.github 9d3c7e7bdc chore(ci): remove build fmt check 1 год назад
docs 435d39a078 feat: add Groq translation support via llama-3-3-70b-versatile, and updated translation service documentation 1 год назад
pdf2zh f30133e040 Merge pull request #431 from timelic/dev/dynamic-line-space 1 год назад
script d0b8e42d57 feat (docker): add a docker file for cn mirrors 1 год назад
test a0a832276d chore : format 1 год назад
.dockerignore 8a20102508 feat (docker): onnx model and font embedded (#276) 1 год назад
.gitignore 8a20102508 feat (docker): onnx model and font embedded (#276) 1 год назад
.pre-commit-config.yaml 1b7f405970 fix: format 1 год назад
Dockerfile a5c376cc26 optimize font logic 1 год назад
LICENSE 04e1dedd8e Update LICENSE 1 год назад
README.md d6244fc074 doc : update option 1 год назад
app.json 73e1d5291f feat (docker): app.json 1 год назад
pyproject.toml 7ed13c2983 fix: add `fontTools` dep 1 год назад
setup.cfg 583d6b3bc9 chore: format 1 год назад

README.md

English | [简体中文](docs/README_zh-CN.md) | [日本語](docs/README_ja-JP.md) PDF2ZH

PDFMathTranslate

PDF scientific paper translation and bilingual comparison.

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

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

Updates

  • [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)

Preview

Online Service 🌟

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.

Installation and Usage

Methods

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

1. Commandline 1. Python installed (3.8 <= version <= 3.12) 2. Install our package: ```bash pip install pdf2zh ``` 3. Execute translation, files generated in [current working directory](https://chatgpt.com/share/6745ed36-9acc-800e-8a90-59204bd134): ```bash pdf2zh document.pdf ```
2. Portable (w/o Python installed) 1. Download [setup.bat](https://raw.githubusercontent.com/Byaidu/PDFMathTranslate/refs/heads/main/script/setup.bat) 2. Double-click to run.
3. Graphic user interface 1. Python installed (3.8 <= version <= 3.12) 2. Install our package: ```bash pip install pdf2zh ``` 3. Start using in browser: ```bash pdf2zh -i ``` 4. If your browswer has not been started automatically, goto ```bash http://localhost:7860/ ``` See [documentation for GUI](./docs/README_GUI.md) for more details.
4. Docker 1. Pull and run: ```bash 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:

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

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

Advanced Options

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.

cmd

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
--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/

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

Secondary Development (APIs)

For downstream applications, please refer to our document about API Details for futher 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

TODOs

  • [ ] 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

Acknowledgements

Contributors

Alt

Star History

Star History Chart