加载xlsx包报错,R 和 rJava 的架构不匹配(R 是 64 位,而 Java 是 32 位)

> library(rJava)
错误: package or namespace load failed for 'rJava':
loadNamespace()里算'rJava'时.onLoad失败了,详细内容:
调用: inDL(x, as.logical(local), as.logical(now), ...)
错误: 无法载入共享目标对象'C:/Program Files/R/R-4.4.3/library/rJava/libs/x64/rJava.dll'::
LoadLibrary failure: %1 不是有效的 Win32 应用程序。
确认Java架构

Client VM:如果输出中提到的是 Client VM,通常意味着 Java 是 32 位。
对于 64 位的 Java,通常会显示为 Server VM 或明确提到 64-Bit Server VM。
没有提到 64-Bit:输出中没有出现 64-Bit 字样,进一步表明这是 32 位 的 Java。


确认R架构

sessionInfo()
查看输出中的 arch 字段
如果 arch 显示为 x86_64,则表示你的 R 是 64 位。
如果 arch 显示为 i386 或 x86,则表示你的 R 是 32 位。
JDK 1.8 64位安装



32 位和 64 位 Java 可以共存,通过路径、环境变量或 IDE 配置。
设置默认版本
- 如果需要为某个项目或全局环境指定特定版本,可以调整 JAVA_HOME 环境变量:
- 指向 64 位 Java:C:\Program Files\Java\jdk1.8.0_XXX
- 指向 32 位 Java:C:\Program Files (x86)\Java\jdk1.8.0_XXX

重启RStudio,加载成功
