我想XLConnect
在R中使用库.如果我执行
library(XLConnect)
Run Code Online (Sandbox Code Playgroud)
我收到以下错误消息:
JAVA_HOME cannot be determined from the Registry
Run Code Online (Sandbox Code Playgroud)
要解决此问题,我首先设置JAVA_HOME
变量:
Sys.setenv(JAVA_HOME='C:/Program Files (x86)/Java/jre1.8.0_65')
library(XLConnect)
Run Code Online (Sandbox Code Playgroud)
看起来它有助于我走得更远,但后来又遇到了另一个问题:
unable to load shared object 'C:/Program Files/R/R-3.2.2/library/rJava/libs/x64/rJava.dll'
Run Code Online (Sandbox Code Playgroud)
它想知道为什么R无法加载rJava.dll
.至少此文件位于R搜索它的文件夹中:
C:\Program Files\R\R-3.2.2\library\rJava\libs\x64
Run Code Online (Sandbox Code Playgroud)
添加
请注意,该rJava.dll
文件存在且位于那里,R正在搜索它.我想问题是32位和64位版本之间不兼容.我认为因为R抱怨:
% 1 is not a valid Win32 application
Run Code Online (Sandbox Code Playgroud)
那么,为什么R期望它Win32 application`? First, my OS is 64bit, second my Java is also for the 64bit and finally, the `rJava.dll` object is located in the folder with
在名称中是x64`(因此,我认为它也是64位版本).
我遇到了同样的问题。请找到 jvm.dll 应该在(您的 JRE 版本可能不同)
C:\Program Files (x86)\Java\jre1.8.0_65\bin\client
Run Code Online (Sandbox Code Playgroud)
或者
C:\Program Files (x86)\Java\jre1.8.0_65\bin\server
Run Code Online (Sandbox Code Playgroud)
将此路径添加到您的 Windows 系统路径中,您就可以开始了。但是请记住,jre 和 R 的版本应该一致,如果您的 java 是Program Files
64 位,64 bit R
那么从Program Files (x86)
32 位启动,所以使用32 bit R