|
|
@@ -1,12 +1,10 @@
|
|
|
-<div id="top">
|
|
|
-
|
|
|
+<div align="center" xmlns="http://www.w3.org/1999/html">
|
|
|
+<!-- logo -->
|
|
|
<p align="center">
|
|
|
<img src="docs/images/MinerU-logo.png" width="300px" style="vertical-align:middle;">
|
|
|
</p>
|
|
|
|
|
|
-</div>
|
|
|
-<div align="center">
|
|
|
-
|
|
|
+<!-- icon -->
|
|
|
[](https://github.com/opendatalab/MinerU)
|
|
|
[](https://github.com/opendatalab/MinerU)
|
|
|
[](https://github.com/opendatalab/MinerU/issues)
|
|
|
@@ -14,211 +12,266 @@
|
|
|
[](https://badge.fury.io/py/magic-pdf)
|
|
|
[](https://pepy.tech/project/magic-pdf)
|
|
|
[](https://pepy.tech/project/magic-pdf)
|
|
|
+<a href="https://trendshift.io/repositories/11174" target="_blank"><img src="https://trendshift.io/api/badge/repositories/11174" alt="opendatalab%2FMinerU | Trendshift" style="width: 250px; height: 55px;" width="250" height="55"/></a>
|
|
|
|
|
|
-<a href="https://trendshift.io/repositories/11174" target="_blank"><img src="https://trendshift.io/api/badge/repositories/11174" alt="opendatalab%2FMinerU | Trendshift" style="width: 200px; height: 55px;"/></a>
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
+<!-- language -->
|
|
|
+[English](README.md) | [简体中文](README_zh-CN.md)
|
|
|
|
|
|
-[English](README.md) | [简体中文](README_zh-CN.md) | [日本語](README_ja-JP.md)
|
|
|
-
|
|
|
-</div>
|
|
|
-
|
|
|
-<div align="center">
|
|
|
+<!-- hot link -->
|
|
|
<p align="center">
|
|
|
-<a href="https://github.com/opendatalab/MinerU">MinerU: An end-to-end PDF parsing tool based on PDF-Extract-Kit, supporting conversion from PDF to Markdown.</a>🚀🚀🚀<br>
|
|
|
-<a href="https://github.com/opendatalab/PDF-Extract-Kit">PDF-Extract-Kit: A Comprehensive Toolkit for High-Quality PDF Content Extraction</a>🔥🔥🔥
|
|
|
+<a href="https://github.com/opendatalab/PDF-Extract-Kit">PDF-Extract-Kit: High-Quality PDF Extraction Toolkit</a>🔥🔥🔥
|
|
|
</p>
|
|
|
|
|
|
+<!-- join us -->
|
|
|
<p align="center">
|
|
|
- 👋 join us on <a href="https://discord.gg/gPxmVeGC" target="_blank">Discord</a> and <a href="https://cdn.vansin.top/internlm/mineru.jpg" target="_blank">WeChat</a>
|
|
|
+ 👋 join us on <a href="https://discord.gg/Tdedn9GTXq" target="_blank">Discord</a> and <a href="https://cdn.vansin.top/internlm/mineru.jpg" target="_blank">WeChat</a>
|
|
|
</p>
|
|
|
-</div>
|
|
|
-
|
|
|
-# MinerU
|
|
|
-
|
|
|
|
|
|
-## Introduction
|
|
|
-
|
|
|
-MinerU is a one-stop, open-source, high-quality data extraction tool, includes the following primary features:
|
|
|
-
|
|
|
-- [Magic-PDF](#Magic-PDF) PDF Document Extraction
|
|
|
-- [Magic-Doc](#Magic-Doc) Webpage & E-book Extraction
|
|
|
-
|
|
|
-
|
|
|
-# Magic-PDF
|
|
|
-
|
|
|
-
|
|
|
-## Introduction
|
|
|
-
|
|
|
-Magic-PDF is a tool designed to convert PDF documents into Markdown format, capable of processing files stored locally or on object storage supporting S3 protocol.
|
|
|
-
|
|
|
-Key features include:
|
|
|
-
|
|
|
-- Support for multiple front-end model inputs
|
|
|
-- Removal of headers, footers, footnotes, and page numbers
|
|
|
-- Human-readable layout formatting
|
|
|
-- Retains the original document's structure and formatting, including headings, paragraphs, lists, and more
|
|
|
-- Extraction and display of images and tables within markdown
|
|
|
-- Conversion of equations into LaTeX format
|
|
|
-- Automatic detection and conversion of garbled PDFs
|
|
|
-- Compatibility with CPU and GPU environments
|
|
|
-- Available for Windows, Linux and macOS platforms
|
|
|
+</div>
|
|
|
|
|
|
+# Changelog
|
|
|
+- 2024/08/09: Version 0.7.0b1 released, simplified installation process, added table recognition functionality
|
|
|
+- 2024/08/01: Version 0.6.2b1 released, optimized dependency conflict issues and installation documentation
|
|
|
+- 2024/07/05: Initial open-source release
|
|
|
+
|
|
|
+<!-- TABLE OF CONTENT -->
|
|
|
+<details open="open">
|
|
|
+ <summary><h2 style="display: inline-block">Table of Contents</h2></summary>
|
|
|
+ <ol>
|
|
|
+ <li>
|
|
|
+ <a href="#mineru">MinerU</a>
|
|
|
+ <ul>
|
|
|
+ <li><a href="#project-introduction">Project Introduction</a></li>
|
|
|
+ <li><a href="#key-features">Key Features</a></li>
|
|
|
+ <li><a href="#quick-start">Quick Start</a>
|
|
|
+ <ul>
|
|
|
+ <li><a href="#online-demo">Online Demo</a></li>
|
|
|
+ <li><a href="#quick-cpu-demo">Quick CPU Demo</a></li>
|
|
|
+ <li><a href="#using-gpu">Using GPU</a></li>
|
|
|
+ </ul>
|
|
|
+ </li>
|
|
|
+ <li><a href="#usage">Usage</a>
|
|
|
+ <ul>
|
|
|
+ <li><a href="#command-line">Command Line</a></li>
|
|
|
+ <li><a href="#api">API</a></li>
|
|
|
+ <li><a href="#development-guide">Development Guide</a></li>
|
|
|
+ </ul>
|
|
|
+ </li>
|
|
|
+ </ul>
|
|
|
+ </li>
|
|
|
+ <li><a href="#todo">TODO</a></li>
|
|
|
+ <li><a href="#known-issues">Known Issues</a></li>
|
|
|
+ <li><a href="#faq">FAQ</a></li>
|
|
|
+ <li><a href="#all-thanks-to-our-contributors">All Thanks To Our Contributors</a></li>
|
|
|
+ <li><a href="#license-information">License Information</a></li>
|
|
|
+ <li><a href="#acknowledgments">Acknowledgments</a></li>
|
|
|
+ <li><a href="#citation">Citation</a></li>
|
|
|
+ <li><a href="#star-history">Star History</a></li>
|
|
|
+ <li><a href="#magic-doc">Magic-doc</a></li>
|
|
|
+ <li><a href="#magic-html">Magic-html</a></li>
|
|
|
+ <li><a href="#links">Links</a></li>
|
|
|
+ </ol>
|
|
|
+</details>
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+# MinerU
|
|
|
+## Project Introduction
|
|
|
+MinerU is a tool that converts PDFs into machine-readable formats (e.g., markdown, JSON), allowing for easy extraction into any format.
|
|
|
+MinerU was born during the pre-training process of [InternLM](https://github.com/InternLM/InternLM). We focus on solving symbol conversion issues in scientific literature and hope to contribute to technological development in the era of large models.
|
|
|
+Compared to well-known commercial products, MinerU is still young. If you encounter any issues or if the results are not as expected, please submit an issue on [issue](https://github.com/opendatalab/MinerU/issues) and **attach the relevant PDF**.
|
|
|
|
|
|
https://github.com/user-attachments/assets/4bea02c9-6d54-4cd6-97ed-dff14340982c
|
|
|
|
|
|
-
|
|
|
-
|
|
|
-## Project Panorama
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-## Flowchart
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-### Dependency repositorys
|
|
|
-
|
|
|
-- [PDF-Extract-Kit : A Comprehensive Toolkit for High-Quality PDF Content Extraction](https://github.com/opendatalab/PDF-Extract-Kit) 🚀🚀🚀
|
|
|
-
|
|
|
-## Getting Started
|
|
|
-
|
|
|
-### Requirements
|
|
|
-
|
|
|
-- Python >= 3.9
|
|
|
-
|
|
|
-Using a virtual environment is recommended to avoid potential dependency conflicts; both venv and conda are suitable.
|
|
|
-For example:
|
|
|
+## Key Features
|
|
|
+
|
|
|
+- Removes elements such as headers, footers, footnotes, and page numbers while maintaining semantic continuity
|
|
|
+- Outputs text in a human-readable order from multi-column documents
|
|
|
+- Retains the original structure of the document, including titles, paragraphs, and lists
|
|
|
+- Extracts images, image captions, tables, and table captions
|
|
|
+- Automatically recognizes formulas in the document and converts them to LaTeX
|
|
|
+- Automatically recognizes tables in the document and converts them to LaTeX
|
|
|
+- Automatically detects and enables OCR for corrupted PDFs
|
|
|
+- Supports both CPU and GPU environments
|
|
|
+- Supports Windows, Linux, and Mac platforms
|
|
|
+
|
|
|
+## Quick Start
|
|
|
+
|
|
|
+If you encounter any installation issues, please first consult the <a href="#faq">FAQ</a>. </br>
|
|
|
+If the parsing results are not as expected, refer to the <a href="#known-issues">Known Issues</a>. </br>
|
|
|
+There are three different ways to experience MinerU:
|
|
|
+- [Online Demo (No Installation Required)](#online-demo)
|
|
|
+- [Quick CPU Demo (Windows, Linux, Mac)](#quick-cpu-demo)
|
|
|
+- [Linux/Windows + CUDA](#Using-GPU)
|
|
|
+
|
|
|
+**⚠️ Pre-installation Notice—Hardware and Software Environment Support**
|
|
|
+
|
|
|
+To ensure the stability and reliability of the project, we only optimize and test for specific hardware and software environments during development. This ensures that users deploying and running the project on recommended system configurations will get the best performance with the fewest compatibility issues.
|
|
|
+
|
|
|
+By focusing resources on the mainline environment, our team can more efficiently resolve potential bugs and develop new features.
|
|
|
+
|
|
|
+In non-mainline environments, due to the diversity of hardware and software configurations, as well as third-party dependency compatibility issues, we cannot guarantee 100% project availability. Therefore, for users who wish to use this project in non-recommended environments, we suggest carefully reading the documentation and FAQ first. Most issues already have corresponding solutions in the FAQ. We also encourage community feedback to help us gradually expand support.
|
|
|
+
|
|
|
+<table>
|
|
|
+ <tr>
|
|
|
+ <td colspan="3" rowspan="2">Operating System</td>
|
|
|
+ </tr>
|
|
|
+ <tr>
|
|
|
+ <td>Ubuntu 22.04 LTS</td>
|
|
|
+ <td>Windows 10 / 11</td>
|
|
|
+ <td>macOS 11+</td>
|
|
|
+ </tr>
|
|
|
+ <tr>
|
|
|
+ <td colspan="3">CPU</td>
|
|
|
+ <td>x86_64</td>
|
|
|
+ <td>x86_64</td>
|
|
|
+ <td>x86_64 / arm64</td>
|
|
|
+ </tr>
|
|
|
+ <tr>
|
|
|
+ <td colspan="3">Memory</td>
|
|
|
+ <td colspan="3">16GB or more, recommended 32GB+</td>
|
|
|
+ </tr>
|
|
|
+ <tr>
|
|
|
+ <td colspan="3">Python Version</td>
|
|
|
+ <td colspan="3">3.10</td>
|
|
|
+ </tr>
|
|
|
+ <tr>
|
|
|
+ <td colspan="3">Nvidia Driver Version</td>
|
|
|
+ <td>latest (Proprietary Driver)</td>
|
|
|
+ <td>latest</td>
|
|
|
+ <td>None</td>
|
|
|
+ </tr>
|
|
|
+ <tr>
|
|
|
+ <td colspan="3">CUDA Environment</td>
|
|
|
+ <td>Automatic installation [12.1 (pytorch) + 11.8 (paddle)]</td>
|
|
|
+ <td>11.8 (manual installation) + cuDNN v8.7.0 (manual installation)</td>
|
|
|
+ <td>None</td>
|
|
|
+ </tr>
|
|
|
+ <tr>
|
|
|
+ <td rowspan="2">GPU Hardware Support List</td>
|
|
|
+ <td colspan="2">Minimum Requirement 8G+ VRAM</td>
|
|
|
+ <td colspan="2">3060ti/3070/3080/3080ti/4060/4070/4070ti<br>
|
|
|
+ 8G VRAM only enables layout and formula recognition acceleration</td>
|
|
|
+ <td rowspan="2">None</td>
|
|
|
+ </tr>
|
|
|
+ <tr>
|
|
|
+ <td colspan="2">Recommended Configuration 16G+ VRAM</td>
|
|
|
+ <td colspan="2">3090/3090ti/4070ti super/4080/4090<br>
|
|
|
+ 16G or more can enable layout, formula recognition, and OCR acceleration simultaneously</td>
|
|
|
+ </tr>
|
|
|
+</table>
|
|
|
+
|
|
|
+### Online Demo
|
|
|
+
|
|
|
+[Click here for the online demo](https://opendatalab.com/OpenSourceTools/Extractor/PDF)
|
|
|
+
|
|
|
+### Quick CPU Demo
|
|
|
+
|
|
|
+#### 1. Install magic-pdf
|
|
|
```bash
|
|
|
conda create -n MinerU python=3.10
|
|
|
conda activate MinerU
|
|
|
+pip install magic-pdf[full]==0.7.0b1 --extra-index-url https://wheels.myhloli.com
|
|
|
```
|
|
|
-
|
|
|
-### Installation and Configuration
|
|
|
-
|
|
|
-#### 1. Install Magic-PDF
|
|
|
-
|
|
|
-**1.Install dependencies**
|
|
|
-
|
|
|
-The full-feature package depends on detectron2, which requires a compilation installation.
|
|
|
-If you need to compile it yourself, please refer to https://github.com/facebookresearch/detectron2/issues/5114
|
|
|
-Alternatively, you can directly use our precompiled whl package (limited to Python 3.10):
|
|
|
-
|
|
|
-```bash
|
|
|
-pip install detectron2 --extra-index-url https://wheels.myhloli.com
|
|
|
-```
|
|
|
-
|
|
|
-**2.Install the full-feature package with pip**
|
|
|
->Note: The pip-installed package supports CPU-only and is ideal for quick tests.
|
|
|
->
|
|
|
->For CUDA/MPS acceleration in production, see [Acceleration Using CUDA or MPS](#4-Acceleration-Using-CUDA-or-MPS).
|
|
|
-
|
|
|
-```bash
|
|
|
-pip install magic-pdf[full]==0.6.2b1
|
|
|
-```
|
|
|
-> ❗️❗️❗️
|
|
|
-> We have pre-released the 0.6.2 beta version, addressing numerous issues mentioned in our logs. However, this build has not undergone full QA testing and does not represent the final release quality. Should you encounter any problems, please promptly report them to us via issues or revert to using version 0.6.1.
|
|
|
-> ```bash
|
|
|
-> pip install magic-pdf[full-cpu]==0.6.1
|
|
|
-> ```
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-#### 2. Downloading model weights files
|
|
|
-
|
|
|
-For detailed references, please see below [how_to_download_models](docs/how_to_download_models_en.md)
|
|
|
-
|
|
|
-After downloading the model weights, move the 'models' directory to a directory on a larger disk space, preferably an SSD.
|
|
|
-
|
|
|
-
|
|
|
-#### 3. Copy the Configuration File and Make Configurations
|
|
|
-You can get the [magic-pdf.template.json](magic-pdf.template.json) file in the repository root directory.
|
|
|
+#### 2. Download model weight files
|
|
|
+
|
|
|
+Refer to [How to Download Model Files](docs/how_to_download_models_en.md) for detailed instructions.
|
|
|
+> ❗️After downloading the models, please make sure to verify the completeness of the model files.
|
|
|
+>
|
|
|
+> Check if the model file sizes match the description on the webpage. If possible, use sha256 to verify the integrity of the files.
|
|
|
+
|
|
|
+#### 3. Copy and configure the template file
|
|
|
+You can find the `magic-pdf.template.json` template configuration file in the root directory of the repository.
|
|
|
+> ❗️Make sure to execute the following command to copy the configuration file to your **user directory**; otherwise, the program will not run.
|
|
|
+>
|
|
|
+> The user directory for Windows is `C:\Users\YourUsername`, for Linux it is `/home/YourUsername`, and for macOS it is `/Users/YourUsername`.
|
|
|
```bash
|
|
|
cp magic-pdf.template.json ~/magic-pdf.json
|
|
|
```
|
|
|
-In magic-pdf.json, configure "models-dir" to point to the directory where the model weights files are located.
|
|
|
-
|
|
|
-```json
|
|
|
-{
|
|
|
- "models-dir": "/tmp/models"
|
|
|
-}
|
|
|
-```
|
|
|
-
|
|
|
-
|
|
|
-#### 4. Acceleration Using CUDA or MPS
|
|
|
-If you have an available Nvidia GPU or are using a Mac with Apple Silicon, you can leverage acceleration with CUDA or MPS respectively.
|
|
|
-##### CUDA
|
|
|
-
|
|
|
-You need to install the corresponding PyTorch version according to your CUDA version.
|
|
|
-This example installs the CUDA 11.8 version.More information https://pytorch.org/get-started/locally/
|
|
|
-```bash
|
|
|
-pip install --force-reinstall torch==2.3.1 torchvision==0.18.1 --index-url https://download.pytorch.org/whl/cu118
|
|
|
-```
|
|
|
-> ❗ ️Make sure to specify version
|
|
|
-> ```bash
|
|
|
-> torch==2.3.1 torchvision==0.18.1
|
|
|
-> ```
|
|
|
-> in the command, as these are the highest versions we support. Failing to specify the versions may result in automatically installing higher versions which can cause the program to fail.
|
|
|
|
|
|
-Also, you need to modify the value of "device-mode" in the configuration file magic-pdf.json.
|
|
|
+Find the `magic-pdf.json` file in your user directory and configure the "models-dir" path to point to the directory where the model weight files were downloaded in [Step 2](#2-download-model-weight-files).
|
|
|
+> ❗️Make sure to correctly configure the **absolute path** to the model weight files directory, otherwise the program will not run because it can't find the model files.
|
|
|
+>
|
|
|
+> On Windows, this path should include the drive letter and all backslashes (`\`) in the path should be replaced with forward slashes (`/`) to avoid syntax errors in the JSON file due to escape sequences.
|
|
|
+>
|
|
|
+> For example: If the models are stored in the "models" directory at the root of the D drive, the "model-dir" value should be `D:/models`.
|
|
|
```json
|
|
|
{
|
|
|
- "device-mode":"cuda"
|
|
|
+ // other config
|
|
|
+ "models-dir": "D:/models",
|
|
|
+ "table-config": {
|
|
|
+ "is_table_recog_enable": false, // Table recognition is disabled by default, modify this value to enable it
|
|
|
+ "max_time": 400
|
|
|
+ }
|
|
|
}
|
|
|
```
|
|
|
|
|
|
-##### MPS
|
|
|
|
|
|
-For macOS users with M-series chip devices, you can use MPS for inference acceleration.
|
|
|
-You also need to modify the value of "device-mode" in the configuration file magic-pdf.json.
|
|
|
-```json
|
|
|
-{
|
|
|
- "device-mode":"mps"
|
|
|
-}
|
|
|
-```
|
|
|
+### Using GPU
|
|
|
+If your device supports CUDA and meets the GPU requirements of the mainline environment, you can use GPU acceleration. Please select the appropriate guide based on your system:
|
|
|
|
|
|
+- [Ubuntu 22.04 LTS + GPU](docs/README_Ubuntu_CUDA_Acceleration_en_US.md)
|
|
|
+- [Windows 10/11 + GPU](docs/README_Windows_CUDA_Acceleration_en_US.md)
|
|
|
|
|
|
-### Usage
|
|
|
|
|
|
-#### 1.Usage via Command Line
|
|
|
+## Usage
|
|
|
|
|
|
-###### simple
|
|
|
+### Command Line
|
|
|
|
|
|
```bash
|
|
|
-magic-pdf pdf-command --pdf "pdf_path" --inside_model true
|
|
|
-```
|
|
|
-After the program has finished, you can find the generated markdown files under the directory "/tmp/magic-pdf".
|
|
|
-You can find the corresponding xxx_model.json file in the markdown directory.
|
|
|
-If you intend to do secondary development on the post-processing pipeline, you can use the command:
|
|
|
-```bash
|
|
|
-magic-pdf pdf-command --pdf "pdf_path" --model "model_json_path"
|
|
|
+magic-pdf --help
|
|
|
+Usage: magic-pdf [OPTIONS]
|
|
|
+
|
|
|
+Options:
|
|
|
+ -v, --version display the version and exit
|
|
|
+ -p, --path PATH local pdf filepath or directory [required]
|
|
|
+ -o, --output-dir TEXT output local directory
|
|
|
+ -m, --method [ocr|txt|auto] the method for parsing pdf.
|
|
|
+ ocr: using ocr technique to extract information from pdf,
|
|
|
+ txt: suitable for the text-based pdf only and outperform ocr,
|
|
|
+ auto: automatically choose the best method for parsing pdf
|
|
|
+ from ocr and txt.
|
|
|
+ without method specified, auto will be used by default.
|
|
|
+ --help Show this message and exit.
|
|
|
+
|
|
|
+
|
|
|
+## show version
|
|
|
+magic-pdf -v
|
|
|
+
|
|
|
+## command line example
|
|
|
+magic-pdf -p {some_pdf} -o {some_output_dir} -m auto
|
|
|
```
|
|
|
-In this way, you won't need to re-run the model data, making debugging more convenient.
|
|
|
|
|
|
-
|
|
|
-###### more
|
|
|
-
|
|
|
-```bash
|
|
|
-magic-pdf --help
|
|
|
+`{some_pdf}` can be a single PDF file or a directory containing multiple PDFs.
|
|
|
+The results will be saved in the `{some_output_dir}` directory. The output file list is as follows:
|
|
|
+
|
|
|
+```text
|
|
|
+├── some_pdf.md # markdown file
|
|
|
+├── images # directory for storing images
|
|
|
+├── layout.pdf # layout diagram
|
|
|
+├── middle.json # MinerU intermediate processing result
|
|
|
+├── model.json # model inference result
|
|
|
+├── origin.pdf # original PDF file
|
|
|
+└── spans.pdf # smallest granularity bbox position information diagram
|
|
|
```
|
|
|
|
|
|
+For more information about the output files, please refer to the [Output File Description](docs/output_file_en_us.md).
|
|
|
|
|
|
-#### 2. Usage via Api
|
|
|
+### API
|
|
|
|
|
|
-###### Local
|
|
|
+Processing files from local disk
|
|
|
```python
|
|
|
image_writer = DiskReaderWriter(local_image_dir)
|
|
|
image_dir = str(os.path.basename(local_image_dir))
|
|
|
jso_useful_key = {"_pdf_type": "", "model_list": []}
|
|
|
pipe = UNIPipe(pdf_bytes, jso_useful_key, image_writer)
|
|
|
pipe.pipe_classify()
|
|
|
+pipe.pipe_analyze()
|
|
|
pipe.pipe_parse()
|
|
|
md_content = pipe.pipe_mk_markdown(image_dir, drop_mode="none")
|
|
|
```
|
|
|
|
|
|
-###### Object Storage
|
|
|
+Processing files from object storage
|
|
|
```python
|
|
|
s3pdf_cli = S3ReaderWriter(pdf_ak, pdf_sk, pdf_endpoint)
|
|
|
image_dir = "s3://img_bucket/"
|
|
|
@@ -227,48 +280,49 @@ pdf_bytes = s3pdf_cli.read(s3_pdf_path, mode=s3pdf_cli.MODE_BIN)
|
|
|
jso_useful_key = {"_pdf_type": "", "model_list": []}
|
|
|
pipe = UNIPipe(pdf_bytes, jso_useful_key, s3image_cli)
|
|
|
pipe.pipe_classify()
|
|
|
+pipe.pipe_analyze()
|
|
|
pipe.pipe_parse()
|
|
|
md_content = pipe.pipe_mk_markdown(image_dir, drop_mode="none")
|
|
|
```
|
|
|
|
|
|
-Demo can be referred to [demo.py](demo/demo.py)
|
|
|
-
|
|
|
-
|
|
|
-# Magic-Doc
|
|
|
-
|
|
|
-
|
|
|
-## Introduction
|
|
|
-
|
|
|
-Magic-Doc is a tool designed to convert web pages or multi-format e-books into markdown format.
|
|
|
-
|
|
|
-Key Features Include:
|
|
|
-
|
|
|
-- Web Page Extraction
|
|
|
- - Cross-modal precise parsing of text, images, tables, and formula information.
|
|
|
-
|
|
|
-- E-Book Document Extraction
|
|
|
- - Supports various document formats including epub, mobi, with full adaptation for text and images.
|
|
|
+For detailed implementation, refer to:
|
|
|
+- [demo.py Simplest Processing Method](demo/demo.py)
|
|
|
+- [magic_pdf_parse_main.py More Detailed Processing Workflow](demo/magic_pdf_parse_main.py)
|
|
|
|
|
|
-- Language Type Identification
|
|
|
- - Accurate recognition of 176 languages.
|
|
|
|
|
|
-https://github.com/opendatalab/MinerU/assets/11393164/a5a650e9-f4c0-463e-acc3-960967f1a1ca
|
|
|
+### Development Guide
|
|
|
|
|
|
+TODO
|
|
|
|
|
|
+# TODO
|
|
|
|
|
|
-https://github.com/opendatalab/MinerU/assets/11393164/0f4a6fe9-6cca-4113-9fdc-a537749d764d
|
|
|
+- [ ] Semantic-based reading order
|
|
|
+- [ ] List recognition within the text
|
|
|
+- [ ] Code block recognition within the text
|
|
|
+- [ ] Table of contents recognition
|
|
|
+- [x] Table recognition
|
|
|
+- [ ] Chemical formula recognition
|
|
|
+- [ ] Geometric shape recognition
|
|
|
|
|
|
+# Known Issues
|
|
|
+- Reading order is segmented based on rules, which can cause disordered sequences in some cases
|
|
|
+- Vertical text is not supported
|
|
|
+- Lists, code blocks, and table of contents are not yet supported in the layout model
|
|
|
+- Comic books, art books, elementary school textbooks, and exercise books are not well-parsed yet
|
|
|
+- Enabling OCR may produce better results in PDFs with a high density of formulas
|
|
|
+- If you are processing PDFs with a large number of formulas, it is strongly recommended to enable the OCR function. When using PyMuPDF to extract text, overlapping text lines can occur, leading to inaccurate formula insertion positions.
|
|
|
+- **Table Recognition** is currently in the testing phase; recognition speed is slow, and accuracy needs improvement. Below are some performance test results in an Ubuntu 22.04 LTS + Intel(R) Xeon(R) Platinum 8352V CPU @ 2.10GHz + NVIDIA GeForce RTX 4090 environment for reference.
|
|
|
|
|
|
+| Table Size | Parsing Time |
|
|
|
+|---------------|----------------------------|
|
|
|
+| 6\*5 55kb | 37s |
|
|
|
+| 16\*12 284kb | 3m18s |
|
|
|
+| 44\*7 559kb | 4m12s |
|
|
|
|
|
|
-https://github.com/opendatalab/MinerU/assets/11393164/20438a02-ce6c-4af8-9dde-d722a4e825b2
|
|
|
+# FAQ
|
|
|
+[FAQ in Chinese](docs/FAQ_zh_cn.md)
|
|
|
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-## Project Repository
|
|
|
-
|
|
|
-- [Magic-Doc](https://github.com/InternLM/magic-doc)
|
|
|
- Outstanding Webpage and E-book Extraction Tool
|
|
|
+[FAQ in English](docs/FAQ_en_us.md)
|
|
|
|
|
|
|
|
|
# All Thanks To Our Contributors
|
|
|
@@ -277,22 +331,21 @@ https://github.com/opendatalab/MinerU/assets/11393164/20438a02-ce6c-4af8-9dde-d7
|
|
|
<img src="https://contrib.rocks/image?repo=opendatalab/MinerU" />
|
|
|
</a>
|
|
|
|
|
|
-
|
|
|
# License Information
|
|
|
|
|
|
[LICENSE.md](LICENSE.md)
|
|
|
|
|
|
-The project currently leverages PyMuPDF to deliver advanced functionalities; however, its adherence to the AGPL license may impose limitations on certain use cases. In upcoming iterations, we intend to explore and transition to a more permissively licensed PDF processing library to enhance user-friendliness and flexibility.
|
|
|
+This project currently uses PyMuPDF to achieve advanced functionality. However, since it adheres to the AGPL license, it may impose restrictions on certain usage scenarios. In future iterations, we plan to explore and replace it with a more permissive PDF processing library to enhance user-friendliness and flexibility.
|
|
|
|
|
|
|
|
|
# Acknowledgments
|
|
|
-
|
|
|
+- [PDF-Extract-Kit](https://github.com/opendatalab/PDF-Extract-Kit)
|
|
|
+- [StructEqTable](https://github.com/UniModal4Reasoning/StructEqTable-Deploy)
|
|
|
- [PaddleOCR](https://github.com/PaddlePaddle/PaddleOCR)
|
|
|
- [PyMuPDF](https://github.com/pymupdf/PyMuPDF)
|
|
|
- [fast-langdetect](https://github.com/LlmKira/fast-langdetect)
|
|
|
- [pdfminer.six](https://github.com/pdfminer/pdfminer.six)
|
|
|
|
|
|
-
|
|
|
# Citation
|
|
|
|
|
|
```bibtex
|
|
|
@@ -311,7 +364,6 @@ The project currently leverages PyMuPDF to deliver advanced functionalities; how
|
|
|
}
|
|
|
```
|
|
|
|
|
|
-
|
|
|
# Star History
|
|
|
|
|
|
<a>
|
|
|
@@ -322,7 +374,14 @@ The project currently leverages PyMuPDF to deliver advanced functionalities; how
|
|
|
</picture>
|
|
|
</a>
|
|
|
|
|
|
+# Magic-doc
|
|
|
+[Magic-Doc](https://github.com/InternLM/magic-doc) Fast speed ppt/pptx/doc/docx/pdf extraction tool
|
|
|
+
|
|
|
+# Magic-html
|
|
|
+[Magic-HTML](https://github.com/opendatalab/magic-html) Mixed web page extraction tool
|
|
|
+
|
|
|
# Links
|
|
|
+
|
|
|
- [LabelU (A Lightweight Multi-modal Data Annotation Tool)](https://github.com/opendatalab/labelU)
|
|
|
- [LabelLLM (An Open-source LLM Dialogue Annotation Platform)](https://github.com/opendatalab/LabelLLM)
|
|
|
- [PDF-Extract-Kit (A Comprehensive Toolkit for High-Quality PDF Content Extraction)](https://github.com/opendatalab/PDF-Extract-Kit)
|