使用java实现word转pdf,html以及rtf转word,pdf,html

word,rtf的转换有以下方案,想要免费最靠谱的是LibreOffice方案,

LibreOffice 是一款 免费、开源、跨平台 的办公软件套件,旨在为用户提供高效、全面的办公工具,适用于个人、企业和教育机构。它支持多种操作系统(Windows、macOS、Linux 等),并能兼容微软 Office(如 DOCX、XLSX、PPTX 等)及其他常见文件格式,是替代商业办公软件的理想选择。

LibreOffice不仅能实现rtf转word,还能实现rtf转pdf,转html,word转pdf,转html,相当强大。

LibreOfficewindows安装很简单,linux安装有点复杂,以下是实现方法

方案 优点 缺点 适用场景
Apache POI + RTF 解析 免费、跨平台 开发复杂,格式支持有限 简单 RTF 转换需求
Jacob(COM 调用) 高质量转换 仅 Windows,依赖 Office 企业内网环境(Windows + Office)
Aspose.Words 高质量、跨平台、易用 商业付费 需高质量转换的商业项目
Free Spire.Doc 免费(有限制) 有水印限制 非商业项目或测试用途
HTML 中间转换 灵活 格式丢失风险 对格式要求不高的场景
LibreOffice 无头模式 免费、跨平台、支持复杂格式 依赖安装、资源占用高 需免费处理复杂格式的场景

windows环境安装

进入下载页:下载 LibreOffice | LibreOffice 简体中文官方网站 - 自由免费的办公套件

选择下载msi文件,下载好后直接安装就行了

java实现转换

安装依赖包

java 复制代码
implementation 'org.jodconverter:jodconverter-local:4.4.0'

代码实现 很简单,构建LibreOffice实例和jodConverter实例,然后就能转换了,jodConverter能够通过文件名后缀识别你想要转换的格式

java 复制代码
// 构建并启动 LibreOffice 实例
OfficeManager officeManager = LocalOfficeManager.builder()
        .install()
        .build();
officeManager.start();
// 创建文档转换器
DocumentConverter converter = LocalConverter.builder()
        .officeManager(officeManager)
        .build();
//进行转换
converter.convert(new File("D:\\T_14_3_1_6.rtf")).to(new File("D:\\11.docx"))
        .execute();
officeManager.stop();

Linux安装LibreOffice

我的linux是centos7,核心比较老,只能选择一些老版本,如果你服务器版本新可以选择新版本

老版本下载地址:Index of /libreoffice/old/7.5.9.2/rpm/x86_64

下载安装包以及语言包

把下载好的包上传到/opt目录下,然后进入opt目录进行解压安装

安装LibreOffice

bash 复制代码
# 进入opt目录
cd /opt
# 解压
tar -zxvf LibreOffice_7.5.9.2_Linux_x86-64_rpm.tar.gz
# 进入解压后的RPMS目录
cd LibreOffice_7.5.9.2_Linux_x86-64_rpm/RPMS/
# 安装LibreOffice,如果你是新版本系统可以用dnf命令
yum localinstall *.rpm

安装语言包,跟安装LibreOffice基本一致

bash 复制代码
cd /opt
tar -zxvf LibreOffice_7.5.9_Linux_x86-64_rpm_langpack_zh-CN.tar.gz
cd LibreOffice_7.5.9.2_Linux_x86-64_rpm_langpack_zh-CN/RPMS/
yum localinstall *.rpm

验证是否安装成功

bash 复制代码
libreoffice7.5 --version

看到这个说明安装成功了

解决中文乱码

一般在windows下安装我们的LibreOffice成功后,转换中文都是正常的,但在linux上基本上都会出现乱码的问题。 因为linux中缺少一些中文字体导致的。这个时候我们需要把windos中的字体文件夹上传到linux上,同步一下字体信息。

1.打开windows电脑的C:\Windows,把Fonts压缩成zip包

2.把压缩包上传到 /usr/share/fonts目录下

bash 复制代码
# 安装解压工具
yum -y install unzip
cd /usr/share/fonts
# 解压
unzip Fonts.zip
yum -y install cups-libs fontconfig
# 给Fonts目录权限
chmod -R 755 /usr/share/fonts/Fonts
yum -y install ttmkfdir
ttmkfdir -e /usr/share/X11/fonts/encodings/encodings.dir
# 刷新字体
fc-cache
# 查看安装的字体
fc-list

报错处理

如果运行java时报java.lang.NullPointerException: officeHome must not be null,说明officeHome没有正确识别到,需要手动添加,如果你安装目录是/opt,则officeHome在/opt/libreoffice7.5

修改代码如下

参考博客:Linux Centos系统安装LibreOffice全过程详解_libreoffice安装教程linux-CSDN博客

相关推荐
清风细雨_林木木5 小时前
.docx 和 .doc 都是 Word 文档格式的区别
word
r i c k8 小时前
邮件合并----批量从excel表中导出数据到word中
word·excel
流浪猪头拯救地球1 天前
WPS 和 office (word/excel/ppt) 找到模板所在位置以及更改模板的方式(公文写作格式要求、字体安装、模板下载)
word·excel·wps
2501_920552561 天前
Mac电脑 Office 2024 LTSC 长期支持版(Excel、Word、PPT)
macos·word·powerpoint·excel·mac
Study_Live_Sun3 天前
vue3中,markdown转html,再导出成为word文件
前端·html·word
Dxy12393102164 天前
python在word创建w:t元素
python·word
徐赛俊6 天前
#Word“嵌入式”插图显示不全的解决教程
word
东方佑6 天前
使用 FastMCP 实现 Word 文档与 JSON 数据互转的 Python 服务
python·json·word
Dxy12393102166 天前
通过XML方式在Word段落前添加空白段落
xml·python·word
九月十九7 天前
java使用aspose读取word里的图片
java·word