Ошибка при попытке использовать библиотеку r Java из python с помощью rpy2 - PullRequest
0 голосов
/ 16 июня 2020

У меня возникают проблемы при попытке загрузить rJava из Python с использованием пакета rpy2. Я просмотрел и прочитал много вопросов, но все же ни один не решил мою проблему.

У меня rJava правильно работающая установка в моей среде R.

(base) pri@pri:~$ R

R version 3.6.3 (2020-02-29) -- "Holding the Windsock"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: x86_64-pc-linux-gnu (64-bit)

> library(data.table)
data.table 1.12.8 using 4 threads (see ?getDTthreads).  Latest news: r-datatable.com
> library(rJava)
> 

Однако, когда я пытаюсь загрузить его из Python, используя rpy2, я получаю сообщение об ошибке:

(base) pri@pri:~$ python3
Python 3.7.7 (default, Mar 26 2020, 15:48:22) 
[GCC 7.3.0] :: Anaconda, Inc. on linux
Type "help", "copyright", "credits" or "license" for more information.
>>> import rpy2.robjects as robjects
>>> robjects.r('''library(data.table); library(rJava)''')
R[write to console]: data.table 1.12.8 using 4 threads (see ?getDTthreads).  Latest news: r-datatable.com

R[write to console]: Error: package or namespace load failed for ‘rJava’:
 .onLoad failed in loadNamespace() for 'rJava', details:
  call: dyn.load(file, DLLpath = DLLpath, ...)
  error: unable to load shared object '/home/pri/R/x86_64-pc-linux-gnu-library/3.6/rJava/libs/rJava.so':
  libjvm.so: cannot open shared object file: No such file or directory

Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  File "/home/pri/anaconda3/lib/python3.7/site-packages/rpy2/robjects/__init__.py", line 416, in __call__
    res = self.eval(p)
  File "/home/pri/anaconda3/lib/python3.7/site-packages/rpy2/robjects/functions.py", line 198, in __call__
    .__call__(*args, **kwargs))
  File "/home/pri/anaconda3/lib/python3.7/site-packages/rpy2/robjects/functions.py", line 125, in __call__
    res = super(Function, self).__call__(*new_args, **new_kwargs)
  File "/home/pri/anaconda3/lib/python3.7/site-packages/rpy2/rinterface_lib/conversion.py", line 44, in _
    cdata = function(*args, **kwargs)
  File "/home/pri/anaconda3/lib/python3.7/site-packages/rpy2/rinterface.py", line 623, in __call__
    raise embedded.RRuntimeError(_rinterface._geterrmessage())
rpy2.rinterface_lib.embedded.RRuntimeError: Error: package or namespace load failed for ‘rJava’:
 .onLoad failed in loadNamespace() for 'rJava', details:
  call: dyn.load(file, DLLpath = DLLpath, ...)
  error: unable to load shared object '/home/pri/R/x86_64-pc-linux-gnu-library/3.6/rJava/libs/rJava.so':
  libjvm.so: cannot open shared object file: No such file or directory

Я уже проверил, что двоичные файлы находятся в правильном месте

(base) pri@pri:~$ ls /usr/lib/jvm/default-java/lib/server/
classes.jsa  libjsig.so  libjvm.so  Xusage.txt

и правильно настроен согласно настройкам linux:

(base) pri@pri:~$ cat /usr/lib/R/etc/ldpaths | grep R_JAVA_LD_LIBRARY_PATH
: ${R_JAVA_LD_LIBRARY_PATH=${JAVA_HOME}/lib/server}
if test -n "${R_JAVA_LD_LIBRARY_PATH}"; then
  R_LD_LIBRARY_PATH="${R_LD_LIBRARY_PATH}:${R_JAVA_LD_LIBRARY_PATH}"

Я также пытался добавить это в .libPaths() R из любопытства, но безуспешно:

JDBC_exe = "/usr/lib/jvm/default-java/lib/server/"
robjects.r('''.libPaths(c('{}', .libPaths()))'''\
            .format(JDBC_exe))

Любой указатель на то, что мне здесь не хватает, и как я могу это исправить.

1 Ответ

1 голос
/ 21 июня 2020

Большинство проблем, связанных с динамической c компоновкой, должны быть решены, если значение переменной среды LD_LIBRARY_PATH совместимо с выводом этой команды:

python -m rpy2.situation LD_LIBRARY_PATH
...