LLMs之PDF:MinerU(将PDF文件转换成Markdown和JSON格式)的简介、安装和使用方法、案例应用之详细攻略

LLMs之PDF:MinerU(将PDF文件转换成Markdown和JSON格式)的简介、安装和使用方法、案例应用之详细攻略

目录

MinerU的简介

0、日志

1、MinerU 的主要特点

2、已知问题

MinerU 安装和使用方法

1、MinerU的三种体验方式

T1、在线演示

T2、快速CPU演示

T3、GPU 使用

2、命令行使用

3、Python API 使用

MinerU的案例应用

科学文献处理

数据预处理

知识图谱构建

文档摘要

其他文本挖掘任务


MinerU的简介

2024年7月5日,MinerU是一个高质量的开源工具,用于将PDF文件转换成Markdown和JSON格式。它提供了一站式解决方案,能够高精度地提取PDF文档中的各种信息。

MinerU 项目诞生于InternLM的预训练过程中,旨在解决科学文献中的符号转换问题,并为大模型时代的技术发展做出贡献。 它致力于提供高质量的PDF内容提取,目标是将PDF转换为机器可读的格式,例如Markdown和JSON,方便后续处理和应用。 与商业产品相比,MinerU 仍在发展中,如果遇到问题或结果不理想,建议在GitHub issue中提交问题并附上相关的PDF文件。

MinerU是一个功能强大且易于使用的PDF转换工具,它能够高效地将PDF转换为Markdown和JSON格式,并支持多种高级功能,例如公式识别、表格识别和OCR。 虽然还存在一些已知问题,但其不断更新迭代,并积极吸纳社区反馈,未来有望成为一个更加完善和强大的PDF处理工具。

GitHub地址GitHub - opendatalab/MinerU: A high-quality tool for convert PDF to Markdown and JSON.一站式开源高质量数据提取工具,将PDF转换成Markdown和JSON格式。

0、日志

2024年11月22日发布0.10.0版本。引入了混合OCR文本提取功能,显著提高了在复杂文本分布场景(如密集公式、不规则跨度区域和图像表示的文本)中的解析性能。结合了文本模式中准确内容提取和更快速度的优势,以及在OCR模式中更精确的跨度/行区域识别。 
2024年11月15日发布0.9.3版本。集成了RapidTable进行表格识别,将单表格解析速度提高了10倍以上,同时准确性更高,GPU内存使用率更低。 
2024年11月6日发布0.9.2版本。集成了StructTable-InternVL2-1B模型以实现表格识别功能。 
2024年10月31日发布0.9.0版本。这是一个主要的新版本,进行了广泛的代码重构,解决了许多问题,提高了性能,降低了硬件要求,并增强了可用性: 重构了排序模块代码,使用layoutreader进行阅读顺序排序,确保在各种布局中保持高准确性。 重构了段落拼接模块,实现了跨列、跨页、跨图形和跨表格场景的良好效果。 重构了列表和目录识别功能,显著提高了列表块和目录块的准确性,以及相应文本段落的解析。 重构了图形、表格和描述文本的匹配逻辑,大大提高了将标题和脚注与图形和表格匹配的准确性,并将描述文本的丢失率降低到接近零。 为OCR添加了多语言支持,支持检测和识别84种语言。支持的语言列表请参见OCR语言支持列表。 添加了内存回收逻辑和其他内存优化措施,显著降低了内存使用。启用所有加速功能(不包括表格加速(布局/公式/OCR))的内存需求从16GB降低到8GB,启用所有加速功能的内存需求从24GB降低到10GB。 优化了配置文件功能开关,添加了独立的公式检测开关,在不需要公式检测时可以显著提高速度和解析结果。 集成了PDF-Extract-Kit 1.0: 添加了自研的doclayout_yolo模型,与原始解决方案相比,处理速度提高了10倍以上,同时保持了类似的解析效果,并且可以通过配置文件与layoutlmv3自由切换。 将公式解析升级到unimernet 0.2.1,提高了公式解析的准确性,同时显著降低了内存使用。 由于PDF-Extract-Kit 1.0的仓库变更,您需要重新下载模型。请参阅如何下载模型以获取详细步骤。 
2024年9月27日发布0.8.1版本,修复了一些错误,并提供了在线演示和前端界面的本地化部署版本。 
2024年9月9日:发布0.8.0版本,支持使用Dockerfile快速部署,并在Huggingface和Modelscope上推出演示。
2024年8月30日:发布0.7.1版本,添加了paddle tablemaster表格识别选项 
2024年8月9日:发布0.7.0b1版本,简化了安装过程,添加了表格识别功能 
2024年8月1日:发布0.6.2b1版本,优化了依赖冲突问题和安装文档
2024年7月5日:首次开源发布

1、MinerU 的主要特点

去除页眉、页脚、脚注、页码等干扰信息;以人类可读的顺序输出文本,适应单列、多列和复杂布局;保留原始文档结构,包括标题、段落、列表等;提取图像、图像描述、表格、表格标题和脚注;自动识别并转换公式为LaTeX格式;自动识别并转换表格为HTML格式;自动检测扫描版PDF和乱码PDF并启用OCR功能;OCR支持84种语言的检测和识别;支持多种输出格式,例如多模态和NLP Markdown、按阅读顺序排序的JSON以及丰富的中间格式;支持多种可视化结果,包括布局可视化和跨度可视化,方便确认输出质量;支持CPU和GPU环境;兼容Windows、Linux和Mac平台。

>> 高质量PDF提取工具:MinerU 是一款高质量的工具,能够将PDF文件转换成机器可读的格式,例如Markdown和JSON。这使得数据提取和进一步处理变得非常容易。

>> 多格式输出:支持多种输出格式,包括多模态和NLP Markdown、按阅读顺序排序的JSON以及丰富的中间格式。

>> 结构化保留:能够保留原始文档的结构,包括标题、段落、列表等,保证语义连贯性。

>> 全面信息提取:不仅提取文本,还能够提取图像、图像描述、表格、表格标题和脚注等信息。

>> 公式和表格转换:自动识别并转换文档中的公式为LaTeX格式,表格为HTML格式。

>> OCR支持:自动检测扫描版PDF和乱码PDF,并启用OCR功能,支持84种语言的检测和识别。

>> 布局处理能力强:能够处理单列、多列和复杂布局的文档,并按人类可读的顺序输出文本。 针对复杂的文本分布场景(如密集公式、不规则跨度区域和图像表示的文本)的解析性能也有显著提升。

>> 多种优化:进行了大量的代码重构,解决了诸多问题,提升了性能,降低了硬件要求,并增强了易用性。 包括内存优化,支持多种模型选择,并针对公式检测、表格识别等功能提供了独立开关,方便用户根据需求调整。

>> 多种运行环境支持:支持CPU和GPU环境,兼容Windows、Linux和Mac平台。

>> 开源且持续更新:项目开源,并持续更新和维护,不断改进性能和功能。

2、已知问题

>> 复杂的布局可能会导致阅读顺序错误。

>> 不支持垂直文本。

>> 对一些不常见的列表格式识别可能存在问题。

>> 只支持一级标题。

>> 代码块目前不支持。

>> 漫画书、艺术画册、小学课本和练习题等类型的PDF解析效果可能较差。

>> 复杂的表格识别可能出现行/列识别错误。

>> 对于一些小众语言的PDF,OCR识别可能存在误差。

>> 部分公式在Markdown中可能无法正确渲染。

MinerU 安装和使用方法

1、MinerU的三种体验方式

在线演示(无需安装)、快速CPU演示(Windows、Linux、Mac)和GPU加速(需要CUDA环境)。

T1、在线演示

提供了稳定版和测试版两个版本,无需任何安装,可以直接在网页上进行测试。

T2、快速CPU演示

安装 magic-pdf:使用conda创建名为MinerU的Python 3.10虚拟环境,激活环境后,使用pip安装 magic-pdf[full] 包,并指定额外的索引URL(--extra-index-url https://wheels.myhloli.com)。

下载模型权重文件:参考项目文档中的“如何下载模型文件”部分进行下载。

修改配置文件:脚本会自动生成 magic-pdf.json 文件,用户可以修改该文件中的配置来启用或禁用某些功能,例如表格识别。 配置文件中包含对 layoutlmv3 和 doclayout_yolo 模型、公式识别和表格识别的配置选项,用户可以根据需要进行调整。

T3、GPU 使用

如果设备支持CUDA并满足GPU要求,可以使用GPU加速。 项目提供了Ubuntu 22.04 LTS + GPU和Windows 10/11 + GPU的详细指南。 也提供了使用Docker进行快速部署的方法,但需要至少8GB VRAM的GPU,所有加速功能默认启用。

2、命令行使用

MinerU可以通过命令行进行使用,具体使用方法请参考项目文档中的“命令行”部分。

3、Python API 使用

MinerU 也提供了Python API,方便用户在自己的程序中集成使用,具体使用方法请参考项目文档中的“API”部分。

MinerU的案例应用

MinerU 主要应用于需要从PDF文档中提取结构化数据的场景,例如:

科学文献处理

MinerU最初是为了解决科学文献中的符号转换问题而开发的,可以用于提取文献中的公式、表格、文本等信息,方便后续的分析和处理。

数据预处理

MinerU可以作为数据预处理工具,将PDF文档转换为结构化的数据,用于训练大型语言模型或其他机器学习模型。

知识图谱构建

MinerU可以用于提取PDF文档中的实体关系信息,用于构建知识图谱。

文档摘要

MinerU可以提取PDF文档中的关键信息,用于生成文档摘要。

其他文本挖掘任务

MinerU可以用于各种文本挖掘任务,例如文本分类、情感分析等。

### Mineru Linux 发行版特点 Mineru Linux 是一款专注于加密货币挖矿优化的操作系统。该发行版集了多种预配置工具服务,旨在简化设置过程并提高挖矿效率[^3]。 - **内核优化**:针对不同硬件平台进行了专门调整,特别是GPU性能调优。 - **自动化脚本支持**:提供一键部署环境的能力,减少手动配置时间。 - **集监控组件**:内置温度监测、功耗统计等功能模块,帮助用户实时掌握设备状态。 ### 安装指南 对于希望在 Mineru Linux 中安装 NVIDIA GPU 驱动程序的用户来说,可以根据官方文档指示操作: ```bash sudo mineru-update # 更新软件源列表 sudo mineru-install nvidia-driver # 自动检测最佳驱动版本并完安装 ``` 上述命令会自动识别适合当前系统的NVIDIA驱动版本,并执行完整的安装流程[^4]。 另外,在 Mineru Linux 下安装 NVIDIA Container Toolkit 可通过如下方式实现: ```bash sudo mineru-add-repo nvidia # 添加 NVIDIA 官方仓库 sudo mineru-refresh # 刷新缓存 sudo mineru-install nvidia-container-toolkit # 安装容器工具包 ``` 这将确保所有依赖项都被正确处理,并使 Docker 能够充分利用 NVIDIA 设备资源[^5]。 ### 使用教程 为了更好地利用 Mineru Linux 的特性,建议按照以下指导来启动挖矿作业: 1. 确认已安装所需驱动及 toolkit 后重启机器; 2. 编写或下载合适的挖矿程序(如 ethminer),放置于 `/opt/mining/` 目录下; 3. 创建服务文件以便后台运行挖矿进程; 创建一个名为 `ethminer.service` 文件位于 `/etc/systemd/system/` : ```ini [Unit] Description=Ethminer Service After=network.target [Service] ExecStart=/opt/mining/start.sh Restart=always User=miner [Install] WantedBy=default.target ``` 最后启用此服务以确保开机自启: ```bash sudo systemctl enable ethminer.service sudo systemctl start ethminer.service ``` 以上步骤能够保证 EthminerMineru Linux 平台上稳定工作[^6]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一个处女座的程序猿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值