Latex PDF Translator
Project description
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, Telegram Group or QQ Group.
Updates
- [Nov. 26 2024] CLI now supports online file(s) (by @reycn)
- [Nov. 24 2024] ONNX support to reduce dependency sizes (by @Wybxc)
- [Nov. 23 2024] 🌟 Public Service online! (by @Byaidu)
- [Nov. 23 2024] Firewall for preventing web bots (by @Byaidu)
- [Nov. 22 2024] GUI now supports Italian, and has been improved (by @Byaidu, @reycn)
- [Nov. 22 2024] You can now share your deployed service to others (by @Zxis233)
- [Nov. 22 2024] Now supports Tencent Translation (by @hellofinch)
- [Nov. 21 2024] GUI now supports downloading dual-document (by @reycn)
- [Nov. 20 2024] 🌟 Demo online! (by @reycn)
Preview
Public Service 🌟
Free Service (https://pdf2zh.com/)
You can try our public service online without installation.
Hugging Face Demo
You can try our demo on HuggingFace without installation. Note that the computing resources of the demo are limited, so please avoid abusing them.
Installation and Usage
We provide three methods for using this project: Commandline, Portable, GUI, and Docker.
Method I. Commandline
-
Python installed (3.8 <= version <= 3.12)
-
Install our package:
pip install pdf2zh
-
Execute translation, files generated in current working directory:
pdf2zh document.pdf
Method II. Portable
No need to pre-install Python environment
Download setup.bat and double-click to run
Method III. GUI
-
Python installed (3.8 <= version <= 3.12)
-
Install our package:
pip install pdf2zh
-
Start using in browser:
pdf2zh -i
-
If your browswer has not been started automatically, goto
http://localhost:7860/
See documentation for GUI for more details.
Method IV. Docker
-
Pull and run:
docker pull byaidu/pdf2zh docker run -d -p 7860:7860 byaidu/pdf2zh
-
Open in browser:
http://localhost:7860/
For docker deployment on cloud service:
Advanced Options
Execute the translation command in the command line to generate the translated document example-zh.pdf
and the bilingual document example-dual.pdf
in the current working directory. Use Google as the default translation service.
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.*)" |
Full / partial document translation
-
Entire document
pdf2zh example.pdf
-
Part of the document
pdf2zh example.pdf -p 1-3,5
Specify source and target languages
See Google Languages Codes, DeepL Languages Codes
pdf2zh example.pdf -li en -lo ja
Translate with Different Services
The table below outlines the required environment variables for each translation service. Make sure to set them before using the respective service.
Translator | Service | Environment Variables | Default Values | Notes |
---|---|---|---|---|
Google (Default) | google |
None | N/A | None |
Bing | bing |
None | N/A | None |
DeepL | deepl |
DEEPL_SERVER_URL ,DEEPL_AUTH_KEY |
https://api.deepl.com , [Your Key] |
See DeepL |
DeepLX | deeplx |
DEEPLX_ENDPOINT |
https://api.deepl.com/translate |
See DeepLX |
Ollama | ollama |
OLLAMA_HOST , OLLAMA_MODEL |
http://127.0.0.1:11434 , gemma2 |
See Ollama |
OpenAI | openai |
OPENAI_BASE_URL , OPENAI_API_KEY , OPENAI_MODEL |
https://api.openai.com/v1 , [Your Key] , gpt-4o-mini |
See OpenAI |
Zhipu | zhipu |
ZHIPU_API_KEY , ZHIPU_MODEL |
[Your Key] , glm-4-flash |
See Zhipu |
Silicon | silicon |
SILICON_API_KEY , SILICON_MODEL |
[Your Key] , Qwen/Qwen2.5-7B-Instruct |
See SiliconCloud |
Azure | azure |
AZURE_ENDPOINT , AZURE_API_KEY |
https://api.translator.azure.cn , [Your Key] |
See Azure |
Tencent | tencent |
TENCENTCLOUD_SECRET_ID , TENCENTCLOUD_SECRET_KEY |
[Your ID] , [Your Key] |
See Tencent |
Use -s service
or -s service:model
to specify service:
pdf2zh example.pdf -s openai:gpt-4o-mini
Or specify model with environment variables:
set OPENAI_MODEL=gpt-4o-mini
pdf2zh example.pdf -s openai
Translate wih exceptions
Use regex to specify formula fonts and characters that need to be preserved:
pdf2zh example.pdf -f "(CM[^RT].*|MS.*|.*Ital)" -c "(\(|\||\)|\+|=|\d|[\u0080-\ufaff])"
Specify threads
Use -t
to specify how many threads to use in translation:
pdf2zh example.pdf -t 1
TODO
-
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
Acknowledgements
-
Document merging: PyMuPDF
-
Document parsing: Pdfminer.six
-
Document extraction: MinerU
-
Multi-threaded translation: MathTranslate
-
Layout parsing: DocLayout-YOLO
-
Document standard: PDF Explained, PDF Cheat Sheets
-
Multilingual Font: Go Noto Universal
Contributors
Star History
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file pdf2zh-1.8.7.tar.gz
.
File metadata
- Download URL: pdf2zh-1.8.7.tar.gz
- Upload date:
- Size: 4.1 MB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 7e44767ffbf66cd6b2f26ef84e6dfeaa72fe118775633f97a149d99105b9006f |
|
MD5 | 3aac8d5ccee6f73fcc52eafb91a82533 |
|
BLAKE2b-256 | afa7b11ee4333a6dc1cf66a4b53709ad2ebb6c07b1e1faa52cfbeed76d7eaa58 |
Provenance
The following attestation bundles were made for pdf2zh-1.8.7.tar.gz
:
Publisher:
python-publish.yml
on Byaidu/PDFMathTranslate
-
Statement:
- Statement type:
https://in-toto.io/Statement/v1
- Predicate type:
https://docs.pypi.org/attestations/publish/v1
- Subject name:
pdf2zh-1.8.7.tar.gz
- Subject digest:
7e44767ffbf66cd6b2f26ef84e6dfeaa72fe118775633f97a149d99105b9006f
- Sigstore transparency entry: 154050520
- Sigstore integration time:
- Permalink:
Byaidu/PDFMathTranslate@628d75a03cfaeb70ee7ca14397faa72b856a811b
- Branch / Tag:
refs/tags/v1.8.7
- Owner: https://github.com/Byaidu
- Access:
public
- Token Issuer:
https://token.actions.githubusercontent.com
- Runner Environment:
github-hosted
- Publication workflow:
python-publish.yml@628d75a03cfaeb70ee7ca14397faa72b856a811b
- Trigger Event:
release
- Statement type:
File details
Details for the file pdf2zh-1.8.7-py3-none-any.whl
.
File metadata
- Download URL: pdf2zh-1.8.7-py3-none-any.whl
- Upload date:
- Size: 43.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 7f6f9e1d9a999d3701de35cc902e5d3b6b8796b51930af02747706869f343097 |
|
MD5 | f30dfeabe270c90a412724b508a0a8cd |
|
BLAKE2b-256 | 0637eec91307331d19e4086637083e2aac0be97fdf8040287e16bd2ca4088182 |
Provenance
The following attestation bundles were made for pdf2zh-1.8.7-py3-none-any.whl
:
Publisher:
python-publish.yml
on Byaidu/PDFMathTranslate
-
Statement:
- Statement type:
https://in-toto.io/Statement/v1
- Predicate type:
https://docs.pypi.org/attestations/publish/v1
- Subject name:
pdf2zh-1.8.7-py3-none-any.whl
- Subject digest:
7f6f9e1d9a999d3701de35cc902e5d3b6b8796b51930af02747706869f343097
- Sigstore transparency entry: 154050521
- Sigstore integration time:
- Permalink:
Byaidu/PDFMathTranslate@628d75a03cfaeb70ee7ca14397faa72b856a811b
- Branch / Tag:
refs/tags/v1.8.7
- Owner: https://github.com/Byaidu
- Access:
public
- Token Issuer:
https://token.actions.githubusercontent.com
- Runner Environment:
github-hosted
- Publication workflow:
python-publish.yml@628d75a03cfaeb70ee7ca14397faa72b856a811b
- Trigger Event:
release
- Statement type: