2017-12-13 13 views
0

中にロードされ、私は奇妙な問題を持っている:間違ったバージョンの私の64ビットのWindows 10上でのJava/rJavaに依存するパッケージをインストールしようとしているときに、インストール

> devtools::install_github("ropensci/tabulizer", INSTALL_opts = "--no-multiarch") 
Downloading GitHub repo ropensci/[email protected] 
from URL https://api.github.com/repos/ropensci/tabulizer/zipball/master 
Installing tabulizer 
Downloading GitHub repo ropensci/[email protected] 
from URL https://api.github.com/repos/ropensci/tabulizerjars/zipball/master 
Installing tabulizerjars 
"C:/PROGRA~1/R/R-34~1.2/bin/x64/R" --no-site-file --no-environ --no-save --no-restore --quiet CMD INSTALL \ 
    "C:/Users/binis/AppData/Local/Temp/Rtmpiw2khr/devtools4d7472ae39f9/ropensci-tabulizerjars-60b7cec" \ 
    --library="C:/Users/binis/Documents/R/win-library/3.4" --install-tests 

* installing *source* package 'tabulizerjars' ... 
** R 
** inst 
** preparing package for lazy loading 
** help 
*** installing help indices 
** building package indices 
** testing if installed package can be loaded 
*** arch - i386 
Error: package or namespace load failed for 'tabulizerjars': 
.onLoad failed in loadNamespace() for 'rJava', details: 
    call: inDL(x, as.logical(local), as.logical(now), ...) 
    error: unable to load shared object 'C:/Users/binis/Documents/R/win-library/3.4/rJava/libs/i386/rJava.dll': 
    LoadLibrary failure: %1 is not a valid Win32 application. 

Error: loading failed 
Execution halted 
*** arch - x64 
ERROR: loading failed for 'i386' 
* removing 'C:/Users/binis/Documents/R/win-library/3.4/tabulizerjars' 
Installation failed: Command failed (1) 
"C:/PROGRA~1/R/R-34~1.2/bin/x64/R" --no-site-file --no-environ --no-save --no-restore --quiet CMD INSTALL \ 
    "C:/Users/binis/AppData/Local/Temp/Rtmpiw2khr/devtools4d744e067cae/ropensci-tabulizer-3aad163" \ 
    --library="C:/Users/binis/Documents/R/win-library/3.4" --install-tests 

ERROR: dependency 'tabulizerjars' is not available for package 'tabulizer' 
* removing 'C:/Users/binis/Documents/R/win-library/3.4/tabulizer' 
Installation failed: Command failed (1) 

今、私はこれが見えると承知しています私はJavaバージョンやパス情報を使いこなしてしまったようです。これは、OSのアーキテクチャとJavaアーキテクチャの一致が(Rが同様に64ビットである)、そのjava.homeのは正しくも設定されていることを示し

> library(rJava) 
> .jinit() 
> .jcall("java/lang/System", "S", "getProperty", "java.version") 
[1] "1.8.0_151" 
> .jcall("java/lang/System", "S", "getProperty", "java.home") 
[1] "C:\\Program Files\\Java\\jre1.8.0_151" 
> .jcall("java/lang/System", "S", "getProperty", "sun.arch.data.model") 
[1] "64" 
> .jcall("java/lang/System", "S", "getProperty", "os.arch") 
[1] "amd64" 

:しかし、それはケース(私の知る限り承知しているとして)ではありませんrJavaは私のマシン上でうまく動作します。

エラーメッセージが正しく分かりませんが、インストール中にRが32ビットバージョンのrJavaを読み込もうとしているようです。私はマシン上の32ビットインストールにjava homeを変更することでこれをテストしました:

> options(java.home="C:/Program Files (x86)/Java/jre1.8.0_151") #32-bit version 
> library(rJava) 
Error: package or namespace load failed for ‘rJava’: 
.onLoad failed in loadNamespace() for 'rJava', details: 
    call: inDL(x, as.logical(local), as.logical(now), ...) 
    error: unable to load shared object 'C:/Users/binis/Documents/R/win-library/3.4/rJava/libs/x64/rJava.dll': 
    LoadLibrary failure: %1 is not a valid Win32 application. 

私の前提をサポートするエラーは同じです。しかし、私はインストール中にRが別のJavaバージョンを使用しようとする理由、またはそれをやめる方法を理解していません。エラーは同じままですが、私はGoogleの/ stackoverflowの上でいくつかのより多くの時間を費やした後INSTALL_opts = c("--no-multiarch", "--no-test-load"), type="source"が...

答えて

0

を何でもします場合、私はすでにテストし、私はinstall_githubの構文が明らかにinstall.packagesは若干異なっていることがわかりました。 'INSTALL_opts 'の代わりに、オプションは'args'で呼び出されます。 follwingコマンドは、それゆえ、「不満」せずに例のパッケージをインストールします。

devtools::install_github("ropensci/tabulizer", 
         args = c("--no-multiarch", "--no-test-load")) 

他の人が同じ問題が発生した場合には、私はここにこれを残します。

関連する問題