如何免费将CAJ文献转为PDF?亲测有效的caj2pdf工具使用指南
2026-01-23 04:30:56作者:傅爽业Veleda
中国知网的部分文献仅提供CAJ格式下载,需使用专用软件打开,给文献阅读和管理带来不便。caj2pdf是一款免费开源工具,能帮助用户将CAJ格式文献转换为可编辑的PDF文件,保留文字内容和大纲结构,解决非Windows系统阅读CAJ文件的难题。
🌟 为什么选择caj2pdf?
CAJ(China Academic Journals)是中国知网的专有文献格式,传统转换方法(如CAJViewer打印)会导致PDF内容为图片格式,无法选择文字且丢失大纲。caj2pdf工具的核心优势在于:
- 保留文本可编辑性:转换后的PDF文件支持文字选择和复制
- 完整保留文献大纲:维持原文献的章节结构和目录导航
- 跨平台支持:适用于Windows、Mac OS等多种操作系统
- 完全免费开源:基于GLWTPL许可证,无需支付任何费用
📋 环境和依赖准备
在使用caj2pdf前,需确保系统已安装以下依赖:
- Python 3.3或更高版本
- PyPDF2库(用于PDF文件处理)
- mutool工具(用于PDF操作)
对于非Windows用户,处理HN格式文件还需额外安装:
- C/C++编译器
- libpoppler开发包或libjbig2dec开发包
🚀 安装步骤
-
克隆项目仓库
git clone https://gitcode.com/gh_mirrors/ca/caj2pdf cd caj2pdf -
安装Python依赖
pip install -r requirements.txt -
编译共享库(非Windows系统)
# 使用libpoppler cc -Wall `pkg-config --cflags poppler` -fPIC -shared -o libjbig2codec.so decode_jbig2data.cc `pkg-config --libs poppler` # 或使用libjbig2dec cc -Wall `pkg-config --cflags jbig2dec` -fPIC -shared -o libjbig2codec.so decode_jbig2data_x.cc `pkg-config --libs jbig2dec`
💻 三种核心用法
1. 查看CAJ文件信息
caj2pdf show [input_file]
此命令会显示文件类型、页面数量和大纲项目数,帮助判断文件是否支持转换。
2. 转换CAJ为PDF
caj2pdf convert [input_file] -o/--output [output_file]
这是最常用的转换命令,将CAJ文件转换为PDF格式并保存到指定路径。
3. 提取大纲到现有PDF
caj2pdf outlines [input_file] -o/--output [pdf_file]
当遇到不支持的文件类型或转换Bug时,可先用CAJViewer打印PDF,再用此命令添加大纲。
📝 使用示例
# 查看文件信息
caj2pdf show thesis.caj
# 转换文件
caj2pdf convert thesis.caj -o thesis.pdf
# 添加大纲到PDF
caj2pdf outlines thesis.caj -o printed.pdf
⚠️ 异常情况说明
caj2pdf目前仍在完善中,遇到以下情况可能无法正常转换:
- Unknown file type:遇到未知文件类型
- 转换过程中出现乱码或内容缺失
若遇到上述问题,建议尝试使用CAJViewer打印为PDF后,再使用大纲提取功能添加目录结构。
🤝 如何贡献
该项目欢迎社区贡献,如果你:
- 遇到转换问题,可在Issue中提交反馈(需提供测试样本)
- 熟悉二进制文件分析、图像压缩算法或逆向工程
- 可通过Pull Request提交代码改进
项目核心代码位于:
- 主程序:caj2pdf
- 解析模块:cajparser.py
- 工具函数:utils.py
- 转换逻辑:jbig2dec.py、jbigdec.py
📄 许可证信息
本项目基于GLWTPL(Good Luck With That Public License)许可证开源,允许自由使用和修改,但作者不对使用效果做任何保证。
登录后查看全文
热门项目推荐
相关项目推荐
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0198
cann-learning-hubCANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。Jupyter Notebook0129
MiMo-V2.5-Pro-FP4-DFlashMiMo-V2.5-Pro-FP4-DFlash 是驱动 MiMo-V2.5-Pro-UltraSpeed 的底层模型: FP4 量化骨干网络:对 MoE 专家采用 MXFP4 量化,同时保持模型其他部分的更高精度,在几乎无损质量的前提下,显著减小模型体积并降低内存带宽压力。 BF16 DFlash 草稿生成器:用于块扩散推测解码,每次前向传播可生成一整个块的 tokens,并让骨干网络一步完成验证。 两者协同作用,既降低了每参数的位宽,又减少了骨干网络前向传播的次数,而这两者正是万亿参数模型解码过程中的两大主要成本来源。Python00
JoyAI-EchoJoyAI-Echo,这是一个独立的、仅用于推理的版本,旨在实现分钟级多镜头音视频生成。它采用了经过蒸馏的DMD生成器、配对的跨模态记忆以及故事级别的一致性。其性能的核心在于,一个跨模态视听记忆库能够在长达五分钟的视频中保持角色外观和语音音色的一致性。同时,一个训练后处理流程将基于记忆的强化学习与分布匹配蒸馏相结合,实现了7.5倍的速度提升,显著增强了视觉质量和对齐效果。00
AstrBot✨ 易上手的多平台 LLM 聊天机器人及开发框架 ✨ 平台支持 QQ、QQ频道、Telegram、微信、企微、飞书 | OpenAI、DeepSeek、Gemini、硅基流动、月之暗面、Ollama、OneAPI、Dify 等。附带 WebUI。Python08
handy-ollama动手学Ollama,CPU玩转大模型部署,在线阅读地址:https://datawhalechina.github.io/handy-ollama/Jupyter Notebook07
项目优选
收起
暂无描述
Dockerfile
767
5.02 K
本项目是CANN提供的transformer类大模型算子库,实现网络在NPU上加速计算。
C++
865
1.96 K
本项目是CANN提供的神经网络类计算算子库,实现网络在NPU上加速计算。
C++
691
1.36 K
Ascend Extension for PyTorch
Python
728
903
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
460
455
deepin linux kernel
C
32
16
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
1.09 K
1.12 K
本仓库是 Flutter SDK 与 Flutter Engine 的 OpenHarmony 适配版本,由 CPF-Flutter 团队维护。开发者可使用熟悉的 Flutter 技术栈开发 OpenHarmony 应用,3.35.7 及以后的适配版本可基于本仓库源码构建支持 OpenHarmony 的 Flutter Engine。
Dart
1.02 K
265
Claude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed.
Get Started
Rust
1.92 K
198
CANNBot 是面向 CANN 开发的用于提升开发效率的系列智能体,本仓库为其提供可复用的 Skills 模块。
Python
1.01 K
631